本章内容: Oracle视图介绍与创建、Oracle视图的查询与修改、Oracle的复杂视图

1. Oracle视图介绍与创建

(1)了解常见的数据库对象都有哪些

(2)了解什么是视图以及为什么要使用视图

概念:视图是一个虚拟表,视图当中的数据是来自于基表的

为什么要用视图?

<1>安全原因:限制数据的访问(如:社会保险基金表,可以使用视图只显示姓名和地址,而不显示社会的保险号和工资)

<2>视图可使复杂的查询用于理解和使用

(3)理解视图的分类

简单视图、复杂视图、连接视图、只读视图

简单视图:基于单个表建立、不包括函数表达式以及分组数据

复杂视图:包括函数表达式以及分组数据的一个视图,目的:为了简化查询操作

连接视图:为了简化连接查询

只读视图:只允许使用select语句,只能看

(4)掌握视图的创建

先登录system用户授予创建视图权限给scott用户

创建简单视图

create view emp_view as select empno,ename,sal from emp;

select * from emp_view

创建连接视图

create view demp_view as select d.deptno,d.dname,e.empno,e.ename,e.job

from dept d inner join emp e on e.deptno=d.deptno and d.deptno=10;

接下来查询视图即可,不需要编写多表连接查询语句,很方便

select * from demp_view;

创建只读视图

create view emp_view3 as select empno,ename,sal from emp with read only;

select * from emp_view3

因为是只读视图,试着修改一下

update emp_view3 set sal=sal+50;

报错:无法对只读视图做DML操作

2.Oracle视图的查询与修改

目标:掌握视图上的DML操作、理解视图上定义的check约束的作用、掌握视图的修改与删除

  1. 视图上的DML操作,对视图的DML操作会改变基表中的数据,不能通过视图改变基表结构,如加字段

create view empnew_view as select empno,ename,sal from empnew;

select * from empnew_view; //查询视图

insert into empnew_view(eid,ename,salary) values(99,'qi1qi',66) update emp set ename="qiqi1" where eid=88

delete from emp where eid=88

(2)创建视图时定义check约束

create view empnew_view2 as select * from empnew where deptno=20

with check option constraint ck_view;

这时候往视图中添加数据

insert into empnew_view2(empno,ename,sal) values(22,'qiqi',333);

会报错:ORA-01402: view WITH CHECK OPTION where-clause violation    //视图WITH CHECK OPTION where句子违规

这时候添加或者修改数据的时候应该满足创建视图中的约束条件才能添加

在这里指定部门编号为20即可以添加

insert into empnew_view2(empno,ename,sal,deptno) values(22,'qiqi',333,20) ;

  1. 掌握视图的修改与删除

修改视图:通过下面修改再查询,很明显之前的视图已经被修改

create or replace view empnew_view as select * from emp where job='SALESMAN';

select * from empnew_view;

删除视图 ,只是删除视图定义,并不会删除视图对应基表中的数据

Drop view empnew_view

基表中数据任存在

3.Oracle的复杂视图

(1)了解什么是复杂视图

(2)掌握创建复杂视图的操作,  //复杂查询,指定列的别名,为了防止在视图上执行DML操作,也可以在后面加上with read only

create view job_view2(job,avgsal,sumsal,manxsal,minsal)

as select job,avg(sal),sum(sal),max(sal),min(sal) from emp group by job;

select * from job_view2;

(3)了解复杂视图上执行DML操作的原则

<1>视图中包含一下元素之一不能执行delete操作

Group by 子句

分组函数            //avg,sum,max,min

distinct 关键字

Rownum伪劣

<2>视图中包含一下元素之一不能执行update操作

Group by 子句

分组函数

distinct 关键字

Rownum伪劣

使用表达式定义的列

<3>视图中包含一下元素之一不能执行insert操作

Group by 子句

分组函数

distinct 关键字

Rownum伪劣

使用表达式定义的列

视图上没有包含基本表的not null列

例如上面创建的复杂视图就不能执行delete,update,insert操作,因为有group by 和分组函数存在

Oracle视图(和Mysq一样l)的更多相关文章

  1. Oracle视图分类及各种操作讲解(超级好文)

    目录:一.视图的定义: 二.视图的作用: 三.创建视图: 1.权限 2.语法 3.1  创建简单视图   3.2  创建连接视图  3.2.1 连接视图定义  3.2.2 创建连接视图  3.2.3 ...

  2. Oracle -----视图

    视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...

  3. Oracle视图详解

    转载自:http://blog.itpub.net/29785807/viewspace-1270120/ 一. 视图的定义 视图(view),也称虚表, 不占用物理空间,这个也是相对概念,因为视图本 ...

  4. oracle视图总结

    视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...

  5. oracle视图总结(转)

    视图简介: 视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改.视图基于的表称为基表.视图是存储在数据字典里的一条select语句. 通过创建视图可以提取数 ...

  6. ORACLE 视图的 with check option

    ORACLE 视图的 with check option 我们来看下面的例子: create or replace view testview as select empno,ename from e ...

  7. ORACLE视图添加备注

    ORACLE视图添加备注 版权声明:本文为博主原创文章,未经博主允许不得转载. create or replace view oes_material_series_ref as select t.p ...

  8. Oracle 视图 (待更新, 缓存)

    参考: 视图.索引.存储过程优缺点: http://www.cnblogs.com/SanMaoSpace/p/3147059.html oracle视图总结(转):http://tianwei013 ...

  9. (转)oracle视图详解

    Oracle视图详解   一. 视图的定义 视图(view),也称虚表, 不占用物理空间,这个也是相对概念,因为视图本身的定义语句还是要存储在数据字典里的.视图只有逻辑定义.每次使用的时候,只是重新执 ...

随机推荐

  1. 方法总结:如何实现html页面自动刷新

    使用场景: 1. 页面需要定时刷新,实时加载数据,需要实时查看监控数据(H5中的WebSocket和SSE可以实现局部刷新) 2. 一定时间之后跳转到指定页面(登录注册之类) 3. 前端开发使用伪数据 ...

  2. Linux磁盘管理及LVM讲解

    硬盘接口 硬盘接口分为IDE.SATA.SCSI和SAS四种, IDE接口硬盘多用于家用产品中,也部分应用于服务器.不支持热添加,比较老. SCSI接口的硬盘则主要应用于服务器市场.linux. 而S ...

  3. docker异常问题解决

    解决方法: 发现这个问题出现的时候,并不是所有的docker都会出现,只影响某个docker 停下:docker stop app-6019-bonus 再起来:docker start app-60 ...

  4. Candies POJ - 3159 (最短路+差分约束)

    During the kindergarten days, flymouse was the monitor of his class. Occasionally the head-teacher b ...

  5. Java对象引用和对象赋值

    关于对象与引用之间的一些基本概念. 初学Java时,在很长一段时间里,总觉得基本概念很模糊.后来才知道,在许多Java书中,把对象和对象的引用混为一谈.可是,如果我分不清对象与对象引用,那实在没法很好 ...

  6. 使用ACR122U NFC读卡器对M1卡进行读写操作(可以读写中文)

    因为项目需要,第一次接触到了ACR122U NFC读卡器(非接触式)和M1卡,首先介绍一下想要读写应该知道的基本知识. 我就根据我的理解先叙述一下: ACR122U 是一款连机非接触式智能卡读写器,可 ...

  7. may be a diary?

    [About Me] SD某弱校高二的OIer. qq 995681518,欢迎一起交流~ 喵喵喵喵喵 "当你想要颓废的那一刻,想一想当初为什么走到了这里." 以下文字充满负面情绪 ...

  8. 意识科学初步:David Chalmers的简单问题与困难问题

    这是第一篇关于意识科学的内容.主要谈一下阅读大卫查莫斯的几篇论文的一些观点和思考. 论文作者简介(摘自wiki): David John Chalmers (born 20 April 1966) i ...

  9. typeof获取变量的数据类型 javascript

    获取变量的数据类型:typeof <!DOCTYPE html> <html lang="en"> <head> <meta charse ...

  10. Spring源码学习-容器BeanFactory(三) BeanDefinition的创建-解析Spring的默认标签

    写在前面 上文Spring源码学习-容器BeanFactory(二) BeanDefinition的创建-解析前BeanDefinition的前置操作中Spring对XML解析后创建了对应的Docum ...