SqlServer在视图上创建索引

更新时间:2023-05-14 14:28:40 阅读: 评论:0

SqlServer在视图上创建索引
在视图上创建索引需要三个条件:
⼀、视图必须绑定到架构。
要做到这点,在 CREATE VIEW 语句中,必须加上 WITH SCHEMABINDING,如果是使⽤企业管理器,则在设计界⾯的空⽩处点击右键,属性,选中“绑定到架构”。
⼆、索引必须是唯⼀索引。
要做到这点,在 CREATE INDEX 中必须指定 UNIQUE。
三、索引必须是聚集索引。
要做到这点,在 CREATE INDEX 中必须指定 CLUSTERED。
例:
CREATE VIEW viewFoo WITH SCHEMABINDING
AS
CREATE UNIQUE CLUSTERED INDEX index_viewFoo ON viewFoo(id)
=========================================================================
【视图的要求】
在视图上创建聚集索引之前,该视图必须满⾜下列要求:
1、当执⾏ CREATE VIEW 语句时,ANSI_NULLS 和 QUOTED_IDENTIFIER 选项必须设置为 ON。OBJECTPROPERTY 函数通过ExecIsAnsiNullsOn 或 ExecIsQuotedIdentOn 属性为视图报告此信息。
2、为执⾏所有 CREATE TABLE 语句以创建视图引⽤的表,ANSI_NULLS 选项必须设置为 ON。
3、视图不能引⽤任何其它视图,只能引⽤基表。
4、视图引⽤的所有基表必须与视图位于同⼀个数据库中,并且所有者也与视图相同。
5、必须使⽤ SCHEMABINDING 选项创建视图。SCHEMABINDING 将视图绑定到基础基表的架构。
6、必须已使⽤ SCHEMABINDING 选项创建了视图中引⽤的⽤户定义的函数。
7、表和⽤户定义的函数必须由 2 部分的名称引⽤。不允许使⽤ 1 部分、3 部分和 4 部分的名称。百亩森林
8、视图中的表达式所引⽤的所有函数必须是确定性的。OBJECTPROPERTY 函数的 IsDeterministic 属性报告⽤户定义的函数是否是确定性的。有关更多信息,请参见确定性函数和⾮确定性函数。
9、视图中的 SELECT 语句不能包含下列 Transact-SQL 语法元素:选择列表不能使⽤ * 或 table_name.* 语法指定列。必须显式给出列名。
10、不能在多个视图列中指定⽤作简单表达式的表的列名。如果对列的所有(或只有⼀个例外)引⽤是复杂表达式的⼀部分或是函数的⼀个参数,则可多次引⽤该列。例如,下列选择列表是⾮法的:
SELECT ColumnA, ColumnB, ColumnA
11、执⾏ CREATE INDEX 语句的⽤户必须是视图的所有者。
12、当执⾏ CREATE INDEX 语句时,下列 SET 选项必须设置为 ON:
ANSI_NULLS
ANSI_PADDING
ANSI_WARNINGS
ARITHABORT
CONCAT_NULL_YIELDS_NULL
QUOTED_IDENTIFIERS
13、必须将选项 NUMERIC_ROUNDABORT 选项设置为 OFF。
14、视图不能包含 text、ntext 或 image 列,即使在 CREATE INDEX 语句中没有引⽤它们。
15、如果视图定义中的 SELECT 语句指定了⼀个 GROUP BY ⼦句,则唯⼀聚集索引的键只能引⽤在 GROUP BY ⼦句中指定的列。
=========================================================================
【SQLServer中使⽤索引视图】
在SQL Server中,视图是⼀个保存的T-SQL查询。视图定义由SQL Server保存,以便它能够⽤作⼀个虚拟表来简化查询,并给基表增加另⼀层安全。但是,它并不占⽤数据库的任何空间。实际上,在你查询它之前,视图并不做任何事情。
索引视图
在SQL Server 2000和2005中,你能够给视图增加索引。但是,如果视图只是⼀个保存在数据库中的查询定义,在运⾏前没有⾃⼰的数据,你如何给那个定义建⽴⼀个索引呢?嗯,这⽐较⿇烦。
软炸大虾
索引视图是⼀个已被物化或保存在数据库中的视图。当基本表更新时,给视图建⽴的索引由数据库引擎保存和更新。当你的结果集返回许多⾏并且需要求总数时,索引视图⼗分有⽤。这是因为数据库引擎必须在基表数据更新时维持视图索引,这可能会降低事务的性能。
要给⼀个视图建⽴⼀个索引,视图定义必须遵守某组条件和会话设置,同时要求把基表和视图定义联系起来。如果你确定你的视图满⾜这些标准,你给视图建⽴的第⼀个索引必须是⼀个唯⼀的聚集索引。建⽴的第⼀个视图必须在⼀组栏上,并且被聚集,以便索引被物化。
列表A说明如何建⽴⼀个索引视图。其中的脚本将建⽴SalesHistory表,并给它加载数据。行书春联
下⾯的代码将建⽴⼀个视图来概括表中的数据:
CREATE
VIEW
vw_salesbyproduct
AS
SELECT
Product,
COUNT_BIG(
*
)
as
ProductCount,
SuM
(SalePrice)
as
TotalSales
FROMdbo.SalesHistory
GROUP
BY
Product
由于它只是⼀个T-SQL查询定义,建⽴这个视图不⽤多少时间。建⽴好视图后,你就可以像对⼀个表⼀样对它进⾏查询。
SELECT
Product, TotalSales, ProductCount
FROM
vw_SalesByProduct
WHERE
product
=
'
Computer
'
如果你在SQL Server Management Studio或Query Analyzer中设置选项来查看查询的“执⾏计划”(Execution Plan),你会注意到上⾯的查询使⽤⼀个表扫描来找出Computer产品的总计结果。表扫描⼀般⽤于数据没有索引的情况下,它对整个结果集进⾏扫描以 找出需要的结果。
进⾏⼀些简单的改变,你就能够修改视图,以便你可以给它增加⼀个索引,从⽽改善搜索性能。⾸先,
你必须设定下⾯的会话设置:
SET
ANSI_NULLS
ON
算工资
GO
SET
ANSI_PADDING
ON
GO
SET
ANSI_WARNINGS
ON
GO
SET
CONCAT_NULL_YIELDS_NULL ONGO
GO
SET
QUOTED_IDENTIFIER
ON
GO
SET
NUMERIC_ROUNDABORT
OFF
GO
--
现在你可以建⽴⾃⼰的视图。为使事情更加简单,我建⽴⼀个崭新的视图。
CREATE
VIEW
dbo.vw_SalesByProduct_Indexed
校招自我介绍WITH
英雄联盟探险家SCHEMABINDING
AS
SELECT
Product,
常伴你左右
COUNT_BIG(
*
)
AS
ProductCount,
SUM
(
ISNULL
(SalePrice,
))
中药延胡索
AS
TotalSales
FROM
dbo.SalesHistory
GROUP
BY
Product
GO
--
下⾯的脚本给我们的视图建⽴索引:
CREATE
UNIQUE
CLUSTERED
INDEX
idx_SalesView
ON
vw_SalesByProduct_Indexed(Product)
--
为表明已经给视图建⽴⼀个索引,并且它确实占⽤数据库的空间,运⾏下⾯的脚本查明聚集索引有多少⾏以及视图占⽤多少空间。
EXECUTE
sp_spaceud
'
vw_SalesByProduct_Indexed
'
--
下⾯的SELECT语句和以前的语句相同,只是这次它执⾏⼀个聚集索引搜索,这个过程完成得⾮常快。
SELECT
Product, TotalSales, ProductCount

本文发布于:2023-05-14 14:28:40,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/897526.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:视图   定义   基表   查询   数据库
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图