Oracle 视图(1)建立视图

Oracle视图是数据库中的虚拟表,基于基表数据提供定制化的查询视角。视图主要用于简化用户接口、增强安全性、数据重用和提供不同角度的数据展示。视图分为标准视图、内嵌视图、对象视图和物化视图,每种类型有不同的特性和用途。创建视图时,可以使用WITH CHECK OPTION限制插入和修改条件。复杂的视图可能涉及多个基表,允许DML操作需满足特定条件。视图的使用和管理对于数据库的灵活性和安全性至关重要。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 视图是基于表的表或者视图的逻辑表,与储存数据的表一样都是Oracle的方案对象。
视图通常用于下面:
1、通过提供用户所需要的的基表中的数据,可以简化用户对数据的理解,隐藏表结构的复杂性,而且可以将那些经常使用的使用的查询定义为视图,使用户不必为以后的每次操作指定全部的条件。
2、通过限制对一组预定义的表行或者表列的访问你,可以提供更好的安全性级别。通过Oracle的预授权命令作用于视图,可以让全县被限制在基于的行或列的子集上,提供高细的安全性级别。
3、可以提供不同于基表的角度来呈现视图的数据,了如重命名视图的列,而不会印象到视图所基于的表。
4、隔离应用程序对基表的更改,对数据的更改有时候并不会影响都视图。
二、 视图的分类:
1、标准视图,使用CREATE VIEW 语句创建的存储的的查询,这类视图创建后会保存到数据字典中,并且作为一个方案对象存在。
2、内嵌视图,在SQL查询语句中直接包含一个子查询,比如在SELECT 语句中包含其他的SELECT 字句,实际上创建了内嵌视图。这种视图只在查询存在,不会保存到数据字典中。
3、对象视图,使用对象试图可以将标准的表或者视图转换为对象类型的视图,可以迎合对象类型的查询而不用重建数据表,使得既可以利用对象编程,又可以使用到传统关系型数据查询的优势。对象视图创建后也会在数据字典中保存特性。对象数据实际上仍然以关系数据的形式储存,但是利用对象的封装行、继承等特性,可以为开发人员提供灵活的处理方式。
4、物化视图,这种视图会真实地储存数据,它与标准视图仅储存查询语句大不相同,无话视图是查询结果被提前储存或“物化”的方案对象,它主要用来汇总、计算、复制和分发数据。
三、视图创建的语法

CREATE [OR REPLACE] [FORCE | NOFORCE | ] VIEW view 
[ (alias [, alias] ...) ]
AS subquery
[ WITH CHECK OPTION [ CONSTRAINT constraint ] ]
[ WITH READ ONLY [ CONSTRAINT constraint ] ];

OR REPLACE, 如果视图已经存在,重建创建它。
FORCE ,强制创建视图,二不管基表是否存在。
NOFORCE ,只在基表存在的情况下创建视图(这是默认值)。
view,指定视图的名字。
alias,为由视图查询选择的表达式指定名字(别名的个数必须与由视图SELECT选择的列的个数匹配)。
subquery,是一个完整的SELECT语句(对于在SELECT 列表中的字段可以用别名)。
WITH CHECK OPTION,指定只有可访问的列才能在视图中被插入或者修改。
constraint ,为CHECK OPTION约束指定的名字。
WITH READ ONLY,只读视图,确保在该视图中没有DML操作能被执行。

四、创建简单的视图

--创建视图
CREATE OR REPLACE VIEW v_buser
        AS
        SELECT id 编号, account 账号, email 邮箱, mobile 电话, name 姓名, sex  性别, birth 生日
                FROM buser;
--查询视图
SELECT * FROM v_buser;

在这里插入图片描述

--也可以这样建view
CREATE OR REPLACE VIEW v_buser(
	编号,
	账号,
	邮箱,
	电话,
	姓名,
	性别,
	生日
)
	AS 
	SELECT id, account, email ,mobile ,name ,sex  ,birth 
		FROM buser;

向视图中插入数据,基表是单表的视图可以插入数据,但是注意视图如果只有基表的几个列,没有包含基表中的唯一索引、主键、非空的列,是不能插入数据的。在向视图插入记录,实际是向表插入数据。如果基表被删除,基于基表建立的视图也会不能查询,会提示错误
ORA-04063: view “TEST.V_BUSER” has errors 。
五、使用WITH CHECK OPTION创建视图

CREATE OR REPLACE VIEW v_buser1
		AS 
		SELECT a.id 编号, a.account 帐号,a.email 邮箱, a.mobile 电话, a.name 姓名, a.sex  性别, a.time 时间, a.status 状态
				FROM buser a
		WITH CHECK OPTION CONSTRAINT v_buser1;

向这个视图插入数据会提示错误

六、创建复杂视图
创建俩个基表以上的视图

CREATE OR REPLACE VIEW v_buser
		AS 
		SELECT a.id 编号, a.account 帐号,a.email 邮箱, a.mobile 电话, a.name 姓名, a.sex  性别, b.zhye 余额, a.time 时间, a.status 状态
				FROM buser a, bzhye b
				WHERE a.id = b.id;

向基于俩个基表以上建立视图插入记录条件比较苛刻,如果插入不可行,一般会提示错误 ORA-01776: cannot modify more than one base table through a join view。
当复杂视图涉及多个基表是,其中至少有一个表的所有列都包含在视图中,或者一个表的的主键和不允许为空的列都包含在视图中,同事创建视图的CREATE VIEW 语句SELECT 语句中只是用了WHERE 子句不包含分组,子查询或DISTINCT关键字,这样的视图可以进行DML操作的,。相反,如果视图中的列是有基表经过运算或分组,比如使用表达式、AVG函数或DISTINCT、GROUP BY 等子句组成的,则无法进行DML操作。

--查询视图是否可以更行
SELECT * FROM user_updatable_columns WHERE table_name = '视图名';

在Oracle中,要能对复杂的联接视图进行更新修改,必须要遵循一定的条件,这些条件概述如下所示:
(1)所有的插入、更新和删除草做在同一时刻只能修改视图中的一个基表。
(2)所有课更新的列必须为键保留表中列,如果视图使用WITH CHECK OPTION进行了定义,name所有的联接列和重复列都不能被更新。
(3)只要存在一个键保留表,就能够删除视图中的列,建保留表在FROM 子句中可以重复,如果视图使用WITH CHECK OPTION定义并且键保留表被重复,那么不能从视图中删除行。
(4)在执行插入操作时,只能对保留键表中的列进行插入,如果使用WITH CHECK OPTION进行定义的视图,则不允许进行插入操作。

视图:是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改。视图基于的表称为基表,Oracle数据库对象分为五种:表,视图,序列,索引和同义词。 视图是存储在数据字典里的一条select语句。通过创建视图可以提取数据的逻辑上的集合或组合。 视图的优点: 1.对数据库的访问,因为视图可以有选择性的选取数据库里的一部分。 2.用户通过简单的查询可以从复杂查询中得到结果。 3.维护数据的独立性,试图可从多个表检索数据。 4.对于相同的数据可产生不同的视图视图分为简单视图和复杂视图1、简单视图只从单表里获取数据,复杂视图从多表; 2、简单视图不包含函数和数据组,复杂视图包含; 3、简单视图可以实现DML操作,复杂视图不可以。 语法结构:创建视图 CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias[, alias]...)] AS subquery [WITH CHECK OPTION [CONSTRAINT constraint]] [WITH READ ONLY] 语法解析: OR REPLACE :若所创建的试图已经存在,则替换旧视图; FORCE:不管基表是否存在ORACLE都会自动创建视图(即使基表不存在,也可以创建视图,但是该视图不能正常使用,当基表创建成功后,视图才能正常使用); NOFORCE :如果基表不存在,无法创建视图,该项是默认选项(只有基表都存在ORACLE才会创建视图)。 alias:为视图产生的列定义的别名; subquery :一条完整的SELECT语句,可以在该语句中定义别名; WITH CHECK OPTION :插入或修改的数据行必须满足视图定义的约束; WITH READ ONLY :默认可以通过视图对基表执行增删改操作,但是有很多在基表上的限制(比如:基表中某列不能为空,但是该列没有出现在视图中,则不能通过视图执行insert操作),WITH READ ONLY说明视图是只读视图,不能通过该视图进行增删改操作。现实开发中,基本上不通过视图对表中的数据进行增删改操作。 案例3:基于EMP表和DEPT表创建视图 代码演示:视图 SQL> CREATE OR REPLACE VIEW EMPDETAIL 2 AS 3 SELECT EMPNO,ENAME,JOB,HIREDATE,EMP.DEPTNO,DNAME 4 FROM EMP JOIN DEPT ON EMP.DEPTNO=DEPT.DEPTNO 5 WITH READ ONLY 6 / VIEW CREATED SQL> SELECT * FROM EMPDETAIL; ① EMPNO ENAME JOB HIREDATE DEPTNO DNAME 7369 SMITH CLERK 17-12月-80 20 RESEARCH 7499 ALLEN SALESMAN 20-2月 -81 30 SALES 7521 WARD SALESMAN 22-2月 -81 30 SALES 7566 JONES MANAGER 02-4月 -81 20 RESEARCH 7654 MARTIN SALESMAN 28-9月 -81 30 SALES 7698 BLAKE MANAGER 01-5月 -81 30 SALES 7782 CLARK MANAGER 09-6月 -81 10 ACCOUNTING 7788 SCOTT ANALYST 19-4月 -87 20 RESEARCH 7839 KING PRESIDENT 17-11月-81 10 ACCOUNTING 7844 TURNER SALESMAN 08-9月 -81 30 SALES 7876 ADAMS CLERK 23-5月 -87 20 RESEARCH 7900 JAMES CLERK 03-12月-81 30 SALES 7902 FORD ANALYST 03-12月-81 20 RESEARCH 7934 MILLER CLERK 23-1月 -82 10 ACCOUNTING 14 ROWS SELECTED 代码解析: ① 对视图可以像表一样进行查询。该视图中隐藏了员工的工资。 删除视图可以使用“DROP VIEW 视图名称”,删除视图不会影响基表的数据。 例如: CREATE OR REPLACE VIEW dept_sum_vw(name,minsal,maxsal,avgsal) AS SELECT d.dname,min(e.sal),max(e.sal),avg(e.sal) FROM emp e,dept d WHERE e.deptno=d.deptno GROUP BY d.dname; 视图的定义原则: 1.视图的查询可以使用复杂的SELECT语法,包括连接/分组查询和子查询; 2.在没有WITH CHECK OPTION和 READ ONLY 的情况下,查询中不能使用ORDER BY 子句; 3.如果没有为CHECK OPTION约束命名,系统会自动为之命名,形式为SYS_Cn; 4.OR REPLACE选项可以不删除原视图便可更改其定义并重建,或重新授予对象权限。 视图的查询: 视图创建成功后,可以从视图中检索数据,这点和从表中检索数据一样。 还可以查询视图的全部信息和指定的数据行和列。 如:检索数据: SQL>SELECT * FROM dept_sum_vw; 查询视图定义: SELECT view_name,text from user_views; 其中text显示的内容为视图定义的SELECT语句,可通过DESC USER_VIEWS 得到相关信息。 修改视图: 通过OR REPLACE 重新创建同名视图即可。 视图上的DML 操作: DML操作应遵循的原则: 1.简单视图可以执行DML操作; 2.在视图包含GROUP 函数,GROUP BY子句,DISTINCT关键字时不能删除数据行; 3.在视图不出现下列情况时可通过视图修改基表数据或插入数据: a.视图中包含GROUP 函数,GROUP BY子句,DISTINCT关键字; b.使用表达式定义的列; c.ROWNUM伪列。 d.基表中未在视图中选择的其他列定义为非空且无默认值。 视图可用于保持数据库的完整性,但作用有限。 通过视图执行引用完整性约束可在数据库级执行约束。 WITH CHECK OPTION 子句限定: 通过视图执行的INSERTS和UPDATES操作不能创建视图检索不到的数据行,因为它会对插入或修改的数据行执行完整性约束和数据有效性检查。 例如: CREATE OR REPLACE VIEW vw_emp20 AS SELECT * FROM emp WHERE deptno=20 WITH CHECK OPTION constraint vw_emp20_ck; 视图建立。 查询结果: 复制代码 SELECT empno,ename,job FROM vw_emp20; EMPNO ENAME JOB --------------------- -------------- ------------- 7369 SMITH CLERK 7566 JONES MANAGER 7902 FORD ANALYST 复制代码 修改: UPDATE vw_emp20 SET deptno=20 WHERE empno=7902; 将产生错误: UPDATE vw_emp20 * ERROR 位于第一行: ORA-01402:视图WITH CHECK OPTION 违反WHERE 子句 视图的删除:DROP VIEW VIEW_NAME语句删除视图。 删除视图的定义不影响基表中的数据。 只有视图所有者和具备DROP VIEW权限的用户可以删除视图视图被删除后,基于被删除视图的其他视图或应用将无效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值