SQL Server 2005 视图不能创建索引的问题 为视图建立索引时,发上如上错误 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 CREATE view V_NAME WITH SCHEMABINDING --指定这个AS SELECT xx,xx FROM dbo.表 --必须指定架构..GO 视图的要求在视图上创建聚集索引之前,该视图必须满足下列要求: 当执行 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 AddColAColBSELECT 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) 创建视图的时候,选定“绑定到架构” WITH SCHEMABINDING ,即可 重新创建视图的时候,选定“绑定到架构”或 WITH SCHEMABINDING 即可 其实视图数据的查询最终会反应到物理表上,与其在试图上创建INDEX还不如优化物理表的INDEX。 建立索引视图需要绑定架构,使用WITH SCHEMABINDING 选项。具体参考联机丛书 创建时加了 WITH SCHEMABINDING 可以了,但又新问题了,两表之间使用了LEFT JOIN,不允许建立索引。 简单的分组语句 SQL2008 如何实现与ACCESS 的链接服务器 数据库中,码的最小原则是什么。。。 存储过程中怎么扑获错误信息 创建聚集索引出错,错误如下: 备份 [求教]SQL语句 每周定时统计的问题 用sql语句向另外插入数据时的问题,怎么解决? 数据库系统中如何对大量的数据字典表单进行组织? mssql单个表备份问题? 如何写sql语句
WITH SCHEMABINDING --指定这个
AS
SELECT xx,xx
FROM dbo.表 --必须指定架构..
GO
在视图上创建聚集索引之前,该视图必须满足下列要求: 当执行 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 AddColAColBSELECT 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)
使用WITH SCHEMABINDING 选项。
具体参考联机丛书