正如第27章所讲的那样,SQL Server2000允许你创建索引视图。一个索引的视图是任意在其上定义了聚集索引的视图。当一个CREATE INDEX语句在视图上执行时,视图的结果集在数据库中的组织和存储与具有聚集索引的数据表是一样的。视图中数据表上的数据发生改变将会自动反映到视图中,也会以同样的方式数据表中的变化会反映到索引中。除了聚集索引,你可以在视图上创建其他非聚集索引来提哦共另外的查询性能。视图上的额外的索引可为查询优化器提供更多的选择。
在SQL Server2000的开发版和企业版中,当一个索引视图存在于一个表中,你可以在查询中直接访问视图,优化器将自动考虑使用视图的索引来提高查询性能,就像表中的索引来提高性能一样。即使一个查询没有直接在FROM子句中使用视图名字,查询优化器也将考虑使用索引视图。换句话,当一个查询可能从索引视图中获得好处,查询优化器会替换掉表上的索引,而使用索引视图来满足查询。
SQL Server 2000的所有版本都可以创建索引,但是只有开发版本和企业版将自动使用索引视图来优化查询,这一点很重要。在其他版本中,索引视图将不会用来提高查询性能,除非查询中明确指定视图并且“NOEXPAND”优化指示也被指定。没有NOEXPAND,SQL Server将扩展视图到视图所对应的表并且基于表中的索引进行优化。下面的例子展示了使用NOEXPAND 选项来强制SQL Server来使用视图索引。
Select * from sales_Qty_Rollup WITH (NOEXPAND)
Where stor_id between 'B914' and 'B999' SET ARITHABORT ON
索引视图的确增加了负担并且可能使得SQL Server变得更复杂,因为需要比普通索引花费更多时间来维护。当索引所在的表被修改了,SQL Server不得不修改视图的结果集和视图中的索引。视图索引的范围可能比单个表要大些,特别是假如视图定义在几个大表上。在修改中维护视图及其索引所需的负担所产生的负面影响要比从其获得好处要多些。因为这些额外的维护负担,只在那些获得好处超过其维护负担的视图上创建索引。
索引视图指南
- 在表数据相对静态的视图上创建索引。
- 将被多个查询使用的视图创建索引。
- 保持索引尽可能小,就像表索引一样,越小的索引,SQL Server访问数据越高效。
- 除了开发版和企业版之外,你将需要指定NOEXPAND指示符,否则索引视图将不会用来优化查询。
分享到:
相关推荐
例如,索引视图(Indexed Views)和全文索引(Full-text Indexes)是SQL Server中用于提高特定类型查询性能的高级索引特性。索引视图可以存储视图的结果集,并且可以快速检索;全文索引用于对数据库中的文本数据进行...
- **索引视图(Indexed Views)**:对常被查询的复杂查询结果创建索引,提高查询效率。 - **物化查询结果(Materialized Query Results)**:预先计算并存储查询结果,适用于稳定不变或更新频率低的数据。 - **...
19. **视图索引(View Indexes)**: 为视图创建索引可以加速基于视图的查询,但需权衡额外的存储开销和维护成本。 20. **临时表(Temporary Tables)**: 临时表用于存储临时数据,有全局和局部两种,生命周期仅...
此外,它还支持视图(views)和映射函数(map/reduce),这是CouchDB中的一个重要特性,用于对数据进行索引和聚合操作。通过这些视图,开发者可以创建自定义的查询逻辑,以便高效地访问和分析存储的数据。 在实际...
文本字段(indexed=True表示会被建立索引) def get_model(self): """返回建立索引的模型类""" return SKU def index_queryset(self, using=None): """返回要建立索引的数据查询集""" return self.get_model()....
3. Indexed Views:为视图创建索引,加速查询速度。 总结,TSQL是SQL Server的重要组成部分,它不仅具备SQL的基础查询功能,还引入了存储过程、触发器等高级特性,使数据库管理更加灵活和强大。熟悉和掌握TSQL,...