您的位置:首页 > 数据库 > Oracle

Oracle数据库之视图与索引

2015-06-22 23:44 489 查看

Oracle数据库之视图与索引

1. 视图简介

视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改。

视图基于的表称为基表,视图是存储在数据字典里的一条SELECT语句。通过创建视图可以提取数据的逻辑上的集合或组合。

我们可以像使用表一样使用视图,但需要注意的是:查询视图没有什么限制,插入/更新/删除视图的操作会受到一定的限制;所有针对视图的操作都会影响到视图的基表;为了防止用户通过视图间接修改基表的数据,可以将视图创建为只读视图(带上with read only选项)。

2. 创建视图

语法:

CREATE [OR REPLACE]
[[NO] FORCE] [EDITIONING] VIEW [schema.] view_name
[ ( { alias [ inline_constraint... ]
| out_of_line_constraint
}
[, { alias [ inline_constraint...]
| out_of_line_constraint
}
]
)
| object_view_clause
| XMLType_view_clause
]
AS subquery [ subquery_restriction_clause ] ;


说明:

FORCE:”强制”创建视图,不考虑基表是否存在,也不考虑是否具有使用基表的权限。

alias:视图的列别名,别名的个数必须与SELECT查询中列的个数相同,如果SELECT查询包含函数或表达式,则必须为其定义列别名。

subquery:查询语句。

subquery_restriction_clause:查询语句限制:

WITH { READ ONLY
| CHECK OPTION
} [ CONSTRAINT constraint ]


READ ONLY:创建的视图只能用于查询数据,而不能用于更改数据。

CHECK OPTION:指定对视图执行的dml操作必须满足“视图子查询”的条件,即对通过视图进行的增删改操作进行“检查”,要求增删改操作的数据,必须是SELECT查询所能查询到的数据,否则不允许操作并返回错误提示。

完整的语法结构及说明见:http://docs.oracle.com/cd/E11882_01/server.112/e41084/statements_8004.htm#SQLRF01504

示例:

CREATE OR REPLACE VIEW  vw_dept (name,minsal,maxsal,avgsal)
AS
SELECT d.dname,min(e.salary),max(e.salary),avg(e.salary)
FROM  employee e, dept d
WHERE e.did=d.id
GROUP BY d.dname
WITH READ ONLY;


3. 视图的优点

简化对数据库的访问,因为视图可以有选择性的选取数据库里的一部分。

用户通过简单的查询可以从复杂查询中得到结果。

维护数据的独立性,视图可从多个表中检索数据。

对于相同的数据可产生不同的视图。

提供各种数据表现形式,可以使用各种不同的方式将基表的数据展现在用户面前,以便符合用户的使用习惯。

提供安全性保证,视图提供了一种可以控制的方式,即可以让不同的用户看见不同的列,而不允许访问那些敏感的列,这样就可以保证敏感数据不被用户看见。

简化用户权限的管理,可以将视图的权限授予用户,而不必将基表中某些列的权限授予用户,这样就简化了用户权限的定义。

4. 索引

为了提高查询的速度,当用户对查询速度不满意而需要对数据库的性能进行调校时,优先考虑建立索引。

创建索引语法:

CREATE [UNIQUE] INDEX index_name
ON table(column1 [ASC | DESC] [, column2 [ASC | DESC] ]... ...)


示例:

CREATE INDEX idx_ename ON employee (ename, sal DESC);


适当的使用索引可以提高数据检索速度,可以给经常需要进行查询的字段创建索引。

向表中“添加”行或从表中“删除”行时,必须花费额外的时间来更新该表的索引,所以当需要从大表中检索少数几行时创建索引。一般我们认为当任何单个查询要检索的行小于整个表总行数的10%时,索引就非常有用。

表的主键和唯一键将自动创建索引。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: