oracle视图

视图是一张表,但是是假表。

视图是不存在数据的,它是基于一个表或者多表的逻辑表,视图相当封装一条调用其他数据库的sql语句,然后调用这个视图名,视图在执行这条sql语句。

视图存在的优点:

1、减少代码的重用性,方便快捷。

2、对数据的安全起到了很大的作用。

首先如果不是管理员要创建视图表,就必须  管理员权限  赋予创建视图的权限。

system 管理员:

赋权限:grant create view to scott;       -- scott 是用户;

scott:用户:

创建语法:create view  视图名  as(sql语句);

问:查询出工资大于2000的员工姓名和工资,及部门名字

例:create  view  v_aa  as (select  e.ename, e.sal, d.dname from emp e,dept d where e.deptno = d.deptno and e.sal>2000);

调用:

select * from v_aa;

1、减少代码重用性:

首先是要经常使用的sql语句,如果不经常使用的话,创建了视图也没有起到多大的作用;

像上面的问题一样,如果每次都select  e.ename, e.sal, d.dname from emp e,dept d where e.deptno = d.deptno and e.sal>2000这样写,会很麻烦,也不方 便,还浪费时间。创建视图之后,每次只需要select * from v_aa; 就可以解决问题。

2、安全性:

在我们创建好视图后,我们可以对视图修改,修改的并不只是修改的视图里的内容,而是和真正数据表的内容一起修改。

如果我们只希望他人阅读,而不需要其他人修改等:

我们在创建的视图的时候加入with read only; 如:create  view  v_aa  as (select  e.ename, e.sal, d.dname from emp e,dept d where e.deptno = d.deptno and e.sal>2000) with read only;

with read only 表示只读的意思;

加上这条语句之后,不可以对这个视图进行其他的操作,而是只可以阅读;

 

with check option  限制数据的改变:

如果只希望他人只能修改固定的数据,不能修改其他重要的数据时:

create  view  v_aa  as (select  e.ename, e.sal, d.dname from emp e,dept d where e.deptno = d.deptno and e.sal>2000) with read only;

只能修改本是图显示的数据,不能修改视图没有显示的数据;

这样更有效的对数据的安全得以保证;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值