oracle视图

来源:互联网 发布:淘宝美人药妆 许佳宁 编辑:程序博客网 时间:2024/05/17 21:06

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

视图是不存在数据的,它是基于一个表或者多表的逻辑表,视图相当封装一条调用其他数据库的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;

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

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


0 0
原创粉丝点击