视图是一张表,但是是假表。
视图是不存在数据的,它是基于一个表或者多表的逻辑表,视图相当封装一条调用其他数据库的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;
只能修改本是图显示的数据,不能修改视图没有显示的数据;
这样更有效的对数据的安全得以保证;