1.视图的概念和优点:
视图是基于一个或多个表及视图的一些查询语句, 它象显示数据的视窗, 它本身是不存储数据的.
视图可以限制数据库的访问, 更好的控制权限
使用户使用简单的查询语句
数据的非依赖性
同一数据的不同表现形式
2. 创建视图的语法
SQL> CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view[(alias[, alias]…)]
AS subquery
[WITH CHECK OPTION [CONSTRAINT constraint]]
[WITH READ ONLY]
参数解释:
FORCE 表不存在时,视图仍然可以创建成功
WITH CHECK OPTION 只有符合视图定义的记录才能被插入或修改
WITH READ ONLY 不允许DML操作
Oracle8i以后创建视图可以用order by
eg:(在已有Stu表格的情况下建立IS_Student视图)
CREATE VIEW IS_Student AS SELECT Sno,Sname FROM Stu WHERE SDEPT='music';
修改视图:
语句格式为:
CREATE OR REPLACE VIEW 视图名 AS SELECT 列名 FROM 表名 + WHERE 约束语句;
CREATE OR REPLACE VIEW IS_Student AS SELECT SBIRTH FROM Stu WHERE Sno=05;
注意: 如果用select * from table_name创建的视图
table_name的结构改变后 view要重建或compile后才能显示新的字段内容
查询视图:
SELECT * FROM IS_Student ;
或者利用数据字典查询:
select view_name,text from user_views;
User_updatable_columns视图能查询视图里能被修改的字段