oracle其他数据对象 --- 视图

 

oracle其他数据对象 --- 视图

一 介绍:

1.什么是视图:

    视图是从一个表或多个表中导出的虚表,它与常规表不同之处在于它并不存储数据,它只是在一个存储的查询中定义.视图同真实表一样,也包含一系列带有名称的列和数据。

注:

(1)视图建立在已有表的基础上, 视图赖以建立的这些表称为基表。

(2)向视图提供数据内容的语句为 SELECT 语句, 可以将视图理解为存储起来的 SELECT 语句.

(3)视图向用户提供基表数据的另一种表现形式

3.视图的优点

(1)限制数据访问

(2)简化复杂查询

(3)提供数据的相互独立

(4)同样的数据,可以有不同的显示方式

4.缺点:

    视图不能提高性能。

5.简单视图和复杂视图

视图只用于查询,对查询数据的封装,通过视图形成一个接口来封装sql语句,供他人访问,视图是一种虚表,视图建立在已有表的基础上,视图依赖以建立的这些表称为基表

向视图提供数据内容 的语句为select语句,可以将视图理解为存储起来的select语句

视图向用户提供基表数据的另一种表现形式

简单的视图:

所谓简单的视图是只引用一个表,并且它只从基础表中检索数据,不允许修改其中的数据;

复杂的视图:

复杂的视图是引用多个表,视图越复杂、视图内再查询的表达式就越多越复杂.

6.基于一个表的简单视图

SQL> create view empSal as select * from emp where sal>=3000;

视图已创建。

注:(1)empSql是创建视图的名字 as之后的是查询的条件

视图自动提交

 

7.复杂视图

(1)有group by的为复杂的视图

SQL>create view groupView as select deptno,avg(nvl(sal,0))

as avgSal from emp group by deptno

   

    注:avg(nvl(sal,0))必须使用列别名命名此表达式,也可以这么写:

SQL>create view groupView(deptno,avgSal)

as select deptno,avg(nvl(sal,0)) from emp group by deptno

(2)有多个表的复杂视图创建

SQL> create view groupView1 as (select dname,e.* from (select deptno,avg(nvl(sal,0)) from emp group by deptno) e inner join dept d on d.deptno=e.deptno)

 

8.修改视图

    修改视图用or replace,如:

SQL> create or replace view groupView as (select dname,e.* from (select deptno,avg(nvl(sal,0)) from emp group by deptno) e inner join dept d on d.deptno=e.deptno)

 

9.为查出的字段起别名

SQL> create or replace view empSal(sename,ssal) as select ename,sal from emp where sal>=3000;

或者可以写为:

SQL> create or replace view empSal as select ename rname,sal salry from emp where sal>=3000;   

注:

起别名的时候可以直接在视图的名字后面写上别名,而不在后面查询最大、最小起别名,如:

SQL> create view groupDep(min,max,avg) as 

select min(sal),max(sal),avg(sal) from emp group by deptno;

 

10.删除视图

    drop view grouped;

注:删除视图只能删除视图的定义,并不会删除基表的数据

11.视图中使用DML的规定

1. 可以在简单视图中执行 DML 操作

当视图定义中包含以下元素之一时不能使用delete:

(1)组函数

(2)GROUP BY 子句

(3)DISTINCT 关键字

(4)ROWNUM 伪列

2. 当视图定义中包含以下元素之一时不能使用update :

(1)组函数

(2)   GROUP BY子句

(3)   DISTINCT 关键字

(4)   ROWNUM 伪列

(5)列的定义为表达式

3. 当视图定义中包含以下元素之一时不能使用insert :

(1)   组函数

(2)   GROUP BY子句

(3)   DISTINCT 关键字

(4)ROWNUM 伪列

(5)列的定义为表达式

(6)表中非空的列在视图定义中未包括

 

    从以上的规定中可以看出,视图主要是用来查询语句的,而对DML一般情况下不使用视图

 

12.屏蔽DML操作,使用with read only

SQL> create or replace view empSal(eename,eesal) as select ename,sal from emp where sal>=3000 with read only;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值