oracle中视图可以创建索引吗?

oracle中视图可以创建索引吗?,第1张

oracle中视图可以创建索引,创建索引方法为:

1、打开Navicat。

2、右击oracle数据库,然后点击【打开连接】。

3、点击【其它】,然后点击【索引】,此时显示oracle数据库中所有的索引。

4、点击【新建索引】,进入索引设计界面。

5、在【常规】标签页,设置类型、表格式、表名、列名等。

6、在【高级】标签页,设置表空间、记录等选项。

7、点击【保存】,输入索引名称,然后点击【确定】。

必须使用 SCHEMABINDING 定义视图才能在视图上创建索引。视图定义也必须具有确定性。如果选择列表中的所有表达式、WHERE 和 GROUP BY 子句都具有确定性,则视图也具有确定性。而且,所有键列必须是精确的。只有视图的非键列可能包含浮点表达式(使用 float 数据类型的表达式),而且 float 表达式不能在视图定义的其它任何位置使用。

若要在确定性视图中查找列,请使用 COLUMNPROPERTY 函数(IsDeterministic 属性)。该函数的 IsPrecise 属性可用来确定键列是否精确。

必须先为视图创建唯一的聚集索引,才能为该视图创建非聚集索引。

指定 SCHEMABINDING 时,select_statement 必须包含所引用的表、视图或用户定义函数的两部分名称 (owner.object)。

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

这样一来,可从索引视图检索数据而无需重新编码,由此带来的高效率也使现有查询获益。在视图上创建的第一个索引必须是唯一聚集索引。在创建唯一聚集索引后,可创建其它非聚集索引。视图上的索引命名规则与表上的索引命名规则相同。唯一区别是表名由视图名替换。(Sql Server联机帮助)

语句:Create VIEW vXXX WITH SCHEMABINDING AS……

Create UNIQUE CLUSTERED INDEX idxXXX ON vXXX(cXXX)

一个标准视图转换为一个索引视图必须遵守以下规则:

A.视图必须使用With Schemabinding选项来创建;

如果创建视图时没有with Schemabinding,试图创建视图时就会报错:……因为该视图未绑定到架构

B.在这个视图中不能使用其他视图、导出表、行集函数或自查询,也就是说只能使用表;

C.视图所用到的基本表必须和视图属于同一个所有者;

D.视图只能链接同一个数据库中的表;

E.视图不能包含一个外部链接或自链接,也就是说在链接表时只能使用INNER JOIN并且INNER JOIN前后不能使同一个表,不能使用LEFT(RIGHT) JOIN 或者 LEFT (RIGHT) OUTER JOIN ;

F. 视图不能包含UNION子句、TOP子句、ORDER BY子句、Having子句、Rollup子句、Cube子句、compute子句、Compute By子句或Distinct关键字;

G. 视图不允许使用某些集合函数,如:Count(*)可以使用count_big(*)代替、avg()、max()、min()、stdev()、stdevp()、var()或varp()等;

H. 视图不能使用Select * 这样的语句,也就是说视图的所有字段都必须显示指定;

I. 视图不能包含Text、ntext、image类型的列;

J. 如果视图包含一个Group By子句,那么他必须在Select列中包含count_big(*);

K. 视图中的所有标和用户自定义的函数都必须使用两段式名来引用,即所有者.表或函数名称;

L. 所有的基本表和视图都必须使用 Set Ansi_Nulls On 创建;

M. 在创建索引时或创建索引后执行IUD时,必须显示或隐式地执行:

Set ANSI_NULLS ON

SET ANSI_PADDING ON

SET ANSI_WARNINGS ON

SET ARITHABORT ON

SET CONCAT_NULL_YIELDS_NULL ON

SET QUOTED_IDENTIFIER ON

SET NUMERIC_ROUNDABORT OFF

各个选项的有关信息或意义,可以查阅SQL Server的联机丛书,这里就不再介绍了;

N. 索引视图只有在SQL Server2000的企业版或开发版或者更高的版本中才能创建。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9899104.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存