Oracle视图

Oracle视图


视图是一种非常重要的数据库对象,它的形式类似于普通表,我们可以从视图中查询数据。实际上它是建立在表上的一种虚表,在视图中并不存储真正的数据,而是仅仅保存一条SELECT语句,对视图的访问将被转化为对表的访问。视图所基于的表称为基表,而视图可以认为是对基表的一种查询操作。

SELECT dname FROM dept
WHERE deptno=(SELECT deptno FROM emp a
GROUP BY deptno
HAVING avg(sal)>all(SELECT avg(sal)FROM emp
WHERE deptno!=a.deptno GROUP BY deptno))

用户可以在自己的模式中创建视图,只要具有CREATE VIEW这个系统权限即可。如果希望在其他用户的模式中创建视图,则需要具有CREATE ANY VIEW系统权限。如果一个视图的基表是其他用户模式中的对象,那么当前用户需要具有对这个基表的SELECT权限。

CREATE VIEW视图名
AS SELECT语句
WITH READ ONLY
WITH CHECK OPTION;
  • WITH READ ONLY:限定对视图只能进行查询操作,不能进行DML操作
  • WITH CHECK OPTION:限定DML操作必须满足一定的条件
SQL>CREATE VIEW view_1 AS
SELECT ename, sal, comm FROM emp
WHERE deptno=30;
SQL>CREATE VIEW view_2 AS
SELECT ename, sal, comm FROM emp
WHERE(deptno=30 or deptno=20)and sal>2000
CREATE VIEW view_1(name, salary, comm1)AS
SELECT ename, sal, comm FROM emp
WHERE deptno=30;
SQL>DESC view_1;
名称 是否为空?类型
NAME NULL VARCHAR2(10)
SALARY NULL NUMBER(7,2)
COMM1 NULL NUMBER(7,2)

与当前用户的视图有关的数据字典是USER_VIEWS,查询这个数据字典,可以获得当前用户的视图的相关信息.

SELECT text FROM user_views WHERE view_name='VIEW_2';

在列TEXT中存储的是创建视图时使用的SELECT语句。另外,在数据字典ALL_VIEWS存储的是当前用户可以访问的所有视图的信息,在数据字典DBA_VIEWS存储的是系统中的所有视图的信息,这个数据字典只有DBA可以访问。
如果发现视图的定义不合适,可以对其进行修改。实际上视图中的SELECT语句是不能直接修改的,所以修改视图的一种方法是先删除视图,再重新创建,另一种方法是在创建视图的CREATE语句中使用OR REPLACE选项。

CREATE OR REPLACE VIEW视图名
AS SELECT语句
WITH READ ONLY
WITH CHECK OPTION;
DROP VIEW视图名;
DROP VIEW view_1;
SELECT*FROM view_1;
INSERT INTO view_1 VALUES('MARY',1000,200)
CREATE OR REPLACE VIEW view_2 AS
SELECT ename, sal, comm FROM emp
WHERE(deptno=30 or deptno=20)AND sal>2000;
UPDATE view_2 SET sal=sal-900;
CREATE OR REPLACE VIEW view_2 AS
SELECT ename, sal, comm FROM emp
WHERE(deptno=30 or deptno=20)AND sal>2000
WITH CHECK OPTION;

复杂视图

CREATE OR REPLACE VIEW view_3(deptno, max_sal, min_sal, sum_sal)AS
SELECT deptno, max(sal),min(sal),sum(sal)
FROM emp
GROUP BY deptno;
CREATE OR REPLACE VIEW view_4(empno, ename, dname, sal, comm)AS
SELECT empno, ename, dname, sal*1.1,comm
FROM emp, dept
WHERE emp.deptno=dept.deptno;





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Oracle 视图(View)是一种虚拟表,是基于一个或多个基础表(Base Table)的查询结果集的命名表示。在 Oracle 数据库中,可以通过创建视图来简化复杂的查询,隐藏实际表的结构和数据,以及提供安全性和数据独立性。 以下是 Oracle 视图的创建语法: ```sql CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias1, alias2, ...)] AS select_statement; ``` 其中, - `OR REPLACE`:如果视图已经存在,则用新的定义替换。 - `FORCE`:如果基础表不存在或者视图依赖的对象无效,则仍然创建视图。 - `NOFORCE`:如果基础表不存在或者视图依赖的对象无效,则不创建视图。 - `view_name`:视图的名称。 - `alias1, alias2, ...`:列别名,可以省略。 - `select_statement`:查询语句,用于定义视图。 例如,创建一个简单的视图: ```sql CREATE VIEW emp_view AS SELECT empno, ename, job, sal FROM emp WHERE deptno = 10; ``` 在创建视图后,可以像查询表一样使用视图: ```sql SELECT * FROM emp_view; ``` 还可以在视图中使用聚合函数、子查询、连接等高级语法,例如: ```sql CREATE VIEW dept_sal_view AS SELECT d.dname, SUM(e.sal) AS total_sal FROM dept d, emp e WHERE d.deptno = e.deptno GROUP BY d.dname; ``` 在使用视图时,可以像查询表一样使用它: ```sql SELECT * FROM dept_sal_view; ``` 总之,Oracle 视图是一种非常方便的工具,可以简化复杂的查询,隐藏实际表的结构和数据,提供安全性和数据独立性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值