`

SQL Server:创建索引视图

阅读更多
视图也称为虚拟表,这是因为由视图返回的结果集其一般格式与由列和行组成的表相似,并且,在 SQL 语句中引用视图的方式也与引用表的方式相同。标准视图的结果集不是永久地存储在数据库中。查询每次引用视图时,Microsoft® SQL Server™ 2000 会动态地将生成视图结果集所需的逻辑合并到从基表数据生成完整查询结果集所需的逻辑中。生成视图结果的过程称为视图具体化。有关更多信息,请参见视图解析。

对于标准视图而言,为每个引用视图的查询动态生成结果集的开销很大,特别是对于那些涉及对大量行进行复杂处理(如聚合大量数据或联接许多行)的视图更为可观。若经常在查询中引用这类视图,可通过在视图上创建唯一聚集索引来提高性能。在视图上创建唯一聚集索引时将执行该视图,并且结果集在数据库中的存储方式与带聚集索引的表的存储方式相同。

说明 只有安装了 Microsoft SQL Server 2000 企业版或 Microsoft SQL Server 2000 开发版,才可以创建索引视图。

在视图上创建索引的另一个好处是:查询优化器开始在查询中使用视图索引,而不是直接在 FROM 子句中命名视图。这样一来,可从索引视图检索数据而无需重新编码,由此带来的高效率也使现有查询获益。有关更多信息,请参见在视图上使用索引。

在视图上创建聚集索引可存储创建索引时存在的数据。索引视图还自动反映自创建索引后对基表数据所做的更改,这一点与在基表上创建的索引相同。当对基表中的数据进行更改时,索引视图中存储的数据也反映数据更改。视图的聚集索引必须唯一,从而提高了 SQL Server 在索引中查找受任何数据更改影响的行的效率。

与基表上的索引相比,对索引视图的维护可能更复杂。只有当视图的结果检索速度的效益超过了修改所需的开销时,才应在视图上创建索引。这样的视图通常包括映射到相对静态的数据上、处理多行以及由许多查询引用的视图。

视图的要求
在视图上创建聚集索引之前,该视图必须满足下列要求:

当执行 CREATE VIEW 语句时,ANSI_NULLS 和 QUOTED_IDENTIFIER 选项必须设置为 ON。OBJECTPROPERTY 函数通过 ExecIsAnsiNullsOn 或 ExecIsQuotedIdentOn 属性为视图报告此信息。

为执行所有 CREATE TABLE 语句以创建视图引用的表,ANSI_NULLS 选项必须设置为 ON。

视图不能引用任何其它视图,只能引用基表。

视图引用的所有基表必须与视图位于同一个数据库中,并且所有者也与视图相同。

必须使用 SCHEMABINDING 选项创建视图。SCHEMABINDING 将视图绑定到基础基表的架构。

必须已使用 SCHEMABINDING 选项创建了视图中引用的用户定义的函数。

表和用户定义的函数必须由 2 部分的名称引用。不允许使用 1 部分、3 部分和 4 部分的名称。

视图中的表达式所引用的所有函数必须是确定性的。OBJECTPROPERTY 函数的 IsDeterministic 属性报告用户定义的函数是否是确定性的。有关更多信息,请参见确定性函数和非确定性函数。

视图中的 SELECT 语句不能包含下列 Transact-SQL 语法元素:
选择列表不能使用 * 或 table_name.* 语法指定列。必须显式给出列名。

不能在多个视图列中指定用作简单表达式的表的列名。如果对列的所有(或只有一个例外)引用是复杂表达式的一部分或是函数的一个参数,则可多次引用该列。例如,下列选择列表是非法的:
SELECT ColumnA, ColumnB, ColumnA

下列选择列表是合法的:

SELECT ColumnA, AVG(ColumnA), ColumnA + Column B AS AddColAColB

SELECT SUM(ColumnA), ColumnA % ColumnB AS ModuloColAColB

派生表。

行集函数。

UNION 运算符。

子查询。

外联接或自联接。

TOP 子句。

ORDER BY 子句。

DISTINCT 关键字。

COUNT(*)(允许 COUNT_BIG(*)。)

AVG、MAX、MIN、STDEV、STDEVP、VAR 或 VARP 聚合函数。如果在引用索引视图的查询中指定 AVG、MAX、MIN、STDEV、STDEVP、VAR 或 VARP,如果视图选择列表包含以下替换函数,则优化器会经常计算需要的结果。 复杂聚合函数 替代简单聚合函数
AVG(X)
SUM(X), COUNT_BIG(X)

STDEV(X)
SUM(X), COUNT_BIG(X), SUM(X**2)

STDEVP(X)
SUM(X), COUNT_BIG(X), SUM(X**2)

VAR(X)
SUM(X), COUNT_BIG(X), SUM(X**2)

VARP(X)
SUM(X), COUNT_BIG(X), SUM(X**2)


例如,索引视图选择列表不能包含表达式 AVG(SomeColumn)。如果视图选择列表包含表达式 SUM(SomeColumn) 和 COUNT_BIG(SomeColumn),则 SQL Server 可为引用视图并指定 AVG(SomeColumn) 的查询计算平均数。

引用可为空的表达式的 SUM 函数。
全文谓词 CONTAINS 或 FREETEXT。
COMPUTE 或 COMPUTE BY 子句。
如果没有指定 GROUP BY,则视图选择列表不能包含聚合表达式。
如果指定了 GROUP BY,则视图选择列表必须包含 COUNT_BIG(*) 表达式,并且,视图定义不能指定 HAVING、CUBE 或 ROLLUP。
通过一个既可以取值为 float 值也可以使用 float 表达式求值的表达式而生成的列不能作为索引视图或表的索引的键。
CREATE INDEX 语句的要求
在视图上创建的第一个索引必须是唯一聚集索引。在创建唯一聚集索引后,可创建其它非聚集索引。视图上的索引命名规则与表上的索引命名规则相同。唯一区别是表名由视图名替换。有关更多信息,请参见 CREATE INDEX。

除了一般的 CREATE INDEX 要求外,CREATE INDEX 语句还必须满足下列要求:

执行 CREATE INDEX 语句的用户必须是视图的所有者。
当执行 CREATE INDEX 语句时,下列 SET 选项必须设置为 ON:
ANSI_NULLS
ANSI_PADDING
ANSI_WARNINGS
ARITHABORT
CONCAT_NULL_YIELDS_NULL
QUOTED_IDENTIFIERS
必须将选项 NUMERIC_ROUNDABORT 选项设置为 OFF。
视图不能包含 text、ntext 或 image 列,即使在 CREATE INDEX 语句中没有引用它们。
如果视图定义中的 SELECT 语句指定了一个 GROUP BY 子句,则唯一聚集索引的键只能引用在 GROUP BY 子句中指定的列。
注意事项
创建聚集索引后,对于任何试图为视图修改基本数据而进行的连接,其选项设置必须与创建索引所需的选项设置相同。如果这个执行语句的连接没有适当的选项设置,则 SQL Server 生成错误并回滚任何会影响视图结果集的 INSERT、UPDATE 或 DELETE 语句。有关更多信息,请参见影响结果的 SET 选项。

若除去视图,视图上的所有索引也将被除去。若除去聚集索引,视图上的所有非聚集索引也将被除去。可分别除去非聚集索引。除去视图上的聚集索引将删除存储的结果集,并且优化器将重新象处理标准视图那样处理视图。

尽管 CREATE UNIQUE CLUSTERED INDEX 语句仅指定组成聚集索引键的列,但视图的完整结果集将存储在数据库中。与基表上的聚集索引一样,聚集索引的 B 树结构仅包含键列,但数据行包含视图结果集中的所有列。

若想为现有系统中的视图添加索引,必须计划绑定任何想要放入索引的视图。可以:

除去视图并通过指定 WITH SCHEMABINDING 重新创建它。
创建另一个视图,使其具有与现有视图相同的文本,但是名称不同。优化器将考虑新视图上的索引,即使在查询的 FROM 子句中没有直接引用它。

说明 不能除去参与到用 SCHEMABINDING 子句创建的视图中的表或视图,除非该视图已被除去或更改而不再具有架构绑定。另外,如果对参与具有架构绑定的视图的表执行 ALTER TABLE 语句,而这些语句又会影响视图定义,则这些语句将会失败。

必须确保新视图满足索引视图的所有要求。这可能需要更改视图及其所引用的所有基表的所有权,以便它们都为同一用户所拥有。

分享到:
评论

相关推荐

    浅析SQL Server 2000索引视图:使用索引视图提高查询性能.pdf

    本文将详细分析索引视图的概念、使用方法、优势、局限性以及创建索引视图时需要遵循的规则和注意事项。 首先,索引视图可以被看作是一种特殊的视图,又称为虚拟表。这是因为视图返回的结果集格式与表相似,包含行和...

    通过SQL_Server_2005索引视图提高性能

    创建索引视图需要遵循特定的语法和规则,例如确保视图定义的确定性以及符合SQL Server对视图的要求等。 #### 十四、使用SET选项获得一致的结果 为了确保在创建索引视图时获得一致的结果,需要设置特定的选项,如`...

    SQLServer视图及索引的创建及使用

    资源名称:SQL Server 视图及索引的创建及使用内容简介: 本文档主要讲述的是SQL Server 视图及索引的创建及使用;目的是通过企业管理器和Transact_SQL语句对视图进行创建、修改和删除通过企业管理器。希望本文档会给...

    SQL Server索引视图及性能提高简介

    在SQL Server 2000中,引入了索引视图的概念,使得视图不仅可以作为数据的安全访问机制和逻辑展示方式,还可以通过创建唯一群集索引和非群集索引来优化查询效率。 传统的视图在运行时会被临时实体化,即每次查询...

    SQL Server中用索引视图查看性能状况

    以下是一个创建索引视图的例子,以`SalesHistory`表为基础,创建一个统计每种产品销售数量和总销售额的索引视图: ```sql CREATE VIEW vw_salesbyproduct WITH SCHEMABINDING AS SELECT Product, COUNT_BIG(*) as ...

    利用SQL Server 2005索引视图提高数据库系统性能.pdf

    - 在查询优化器中使用索引视图:SQL Server的查询优化器会自动决定是否对给定的查询执行使用索引视图,这使得无需更改现有应用程序代码,即可实现性能提升。 - 使用N0EXPAND视图提示:该提示可以强制查询优化器将...

    SQL_Server视图和索引

    ##### 3.2 创建索引 - **创建非聚集索引**:非聚集索引是一种索引类型,它不按物理顺序存储数据行,而是根据索引键值进行排序。 ```sql CREATE UNIQUE NONCLUSTERED INDEX ind_cp1 ON 产品 (产品名称 DESC) WITH...

    Sql Server 数据库视图 索引等

    **创建索引示例:** ```sql -- 创建非唯一、非聚集索引 CREATE INDEX ix_名字 ON 表名 (字段名); -- 创建唯一、聚集索引 CREATE UNIQUE CLUSTERED INDEX ix_名字 ON 表名 (字段名); ``` **索引的维护:** - **重建...

    通过SQLServer2005索引视图提高性能[收集].pdf

    当创建索引视图时,系统会为视图创建一个或多个索引,使得查询可以直接使用这些预计算的结果,从而显著提升查询性能。然而,这需要额外的存储空间,并且在数据更新时,索引视图也需要同步更新,这可能会增加维护成本...

    sql server视图详解

    4. **索引视图**:对视图进行了物理存储,以提高查询性能,但需要满足一定的限制条件。 ### 视图的作用 1. **简化查询**:视图可以隐藏复杂的表结构,用户只需操作视图,无需了解底层数据源的细节。 2. **安全机制*...

    Server创建索引视图.pdf

    首先,只有SQL Server的 Enterprise Edition 或 Developer Edition 支持创建索引视图,这是因为它们需要更多的系统资源来处理和维护这些视图。其次,索引视图要求在创建时设置 ANSI_NULLS 和 QUOTED_IDENTIFIER 选项...

    sqlserver 2008 索引与视图 详解

    在SQL Server 2008中,索引和视图是两个重要的概念,它们对于数据库的性能和数据管理起着至关重要的作用。 **索引基础知识** 索引是一种加速数据检索的机制,类似于书籍的目录。在数据库中,索引是由表或视图中一...

    细说SQL Server中的视图

    7,索引视图; 1.什么是视图  视图是由一个查询所定义的虚拟表,它与物理表不同的是,视图中的数据没有物理表现形式,除非你为其创建一个索引;如果查询一个没有索引的视图,Sql Server实际访问的是基础表。  ...

    SQLServer 视图 事务 索引

    创建索引使用`CREATE INDEX`语句,删除索引使用`DROP INDEX`。需要注意的是,虽然索引能加快查询速度,但也会占用额外的存储空间,并可能在插入、更新和删除操作中降低性能。 结合使用视图、事务和索引,数据库管理...

    Server创建索引视图[文].pdf

    1. **环境要求**:只有安装了SQL Server 2000的企业版或开发版才能创建索引视图,因为这种功能需要更高的系统资源和更复杂的管理能力。 2. **语法限制**:在创建索引视图时,`ANSI_NULLS`和`QUOTED_IDENTIFIER`选项...

    三个SQL视图查出所有SQL Server数据库字典

    在SQL Server中,数据库字典是存储有关数据库元数据(如表、列、索引等)的系统表和视图的集合。这些元数据对于了解和管理数据库结构至关重要。通过查询这些系统表或视图,可以获取到关于数据库对象的各种信息。 ##...

    sql server 重新组织和重新生成索引

    SQL Server 重新组织和重新生成索引 在 SQL Server 中,索引的碎片可能会对查询性能产生影响,因此需要对索引进行维护。SQL Server 2005 提供了重新组织和重新生成索引的功能,以修复索引碎片。 重新组织索引 ...

    SQL Server数据库实验指导书 实验教程 数据库实验05 视图的创建与使用.pdf

    5.掌握应用SQL Server Management Studio创建数据库的方法。 6.掌握应用SQL Server Management Studio修改和查看数据库的方法。 7.掌握应用SQL Server Management Studio删除数据库的方法。 8.掌握应用Transact-SQL...

    SQL Server 索引中include的魅力(具有包含性列的索引)

    只能对表或索引视图的非聚集索引定义非键列。除 text、ntext 和 image 之外,允许所有数据类型。 摘要 5:列大小准则:必须至少定义一个键列。最大非键列数为 1023 列,也就是最大的表列数减 1。 SQL Server 索引...

    mysql与sqlserver的基础语法区别

    - SQL Server支持更多的索引类型,如全文索引、空间索引、XML索引等,而MySQL主要支持B树和哈希索引。 7. 数据类型: - 两者都有各自的特有数据类型,如SQL Server的`DATE`、`TIME`、`DATETIMEOFFSET`,MySQL的`...

Global site tag (gtag.js) - Google Analytics