gpt4 book ai didi

sql-server - 如何重写CROSS APPLY to INNER JOIN以使 View 建立索引

转载 作者:行者123 更新时间:2023-12-03 01:59:22 24 4
gpt4 key购买 nike

separate thread上我有一个关于如何将存储过程转换为 View 的工作示例,它将保存客户名称到订单映射,其中订单是逗号分隔的订单列表,包括 NULL 表示没有订单。因此,对于下表,我需要在 View 中显示以下内容:

Name     Orders
'John' New Hat, New Book, New Phone
'Marry' NULL

我需要为 View 建立索引,但如果 View 中的 SELECT 查询具有 APPLY 和/或子查询,则无法执行此操作。是否可以将此 View 转换为索引 View ?

create table Customers (CustomerId int, CustomerName VARCHAR(100))
create table Orders (CustomerId int, OrderName VARCHAR(100))

insert into Customers (CustomerId, CustomerName) select 1, 'John' union all select 2, 'Marry'
insert into Orders (CustomerId, OrderName) select 1, 'New Hat' union all select 1, 'New Book' union all select 1, 'New Phone'
go

create view OrderView as
select c.CustomerName, x.OrderNames
from Customers c
cross apply (select stuff((select ',' + OrderName from Orders o
where o.CustomerId = c.CustomerId for xml path('')),1,1,'')
as OrderNames) x
go

最佳答案

您无法将此 View 编入索引。

基本上,您在这里有一个聚合函数(伪装为CROSS APPLY)。

索引 View 中允许的唯一聚合函数是 COUNT_BIGSUM,因为它们分布在集合加法和减法上,即 SUM(a UNION ALL b) = SUM(a) + SUM(b)SUM(a EXCEPT ALL b) = SUM(a) - SUM(b)

此属性是索引可维护所必需的。

当从基础表中插入、更新或删除新记录时,不需要重新评估整个 View :新记录的值只是从聚合值中添加或减去。

此外,COUNT_BIG 也应该是 View 的一部分,以跟踪记录的删除(当它变为 0 时,应从 View 中删除一条记录)查看索引)。

关于sql-server - 如何重写CROSS APPLY to INNER JOIN以使 View 建立索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4089575/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com