视图
视图简介
视图是由一个或者多个表组成的虚拟表;
那些用于产生视图的表叫做该视图的基表。视图不占用物理空间,这个也是相对概念,因为视图本身的定义语句还是要存储在数据字典里的。视图只有逻辑定义。每次使用的时候只是重新执行SQL。一个视图也可以从另一个视图中产生。视图没有存储真正的数据,真正的数据还是存储在基表中。一般出于对基本的安全性和常用的查询语句会建立视图;并一般情况下不对视图进行新增、更新操作。
【语法】
--创建视图 CREATE [OR REPLACE] VIEW <view_name> AS <SELECT 语句>;
--删除视图 DROP VIEW <view_name> ; |
视图操作
-- 授予zx用户 创建视图 的权限 grant create view to zx;
-- 登录zx,创建视图 create or replace view v_emp as select empno,ename from emp;
--通过视图查询数据 select * from v_emp;
--通过视图添加数据,需要保证基表的其它数据项可以为空 insert into v_emp(empno,ename) values(3333,'zx3');
--通过视图修改数据 update v_emp set ename='it3' where empno=3333;
--通过视图删除数据 delete from v_emp where empno=3333;
--基于多个基表的视图,不建议使用视图进行增删改操作 create or replace view v_dept_emp as select dept.deptno,dept.dname,ename from emp inner join dept on emp.deptno=dept.deptno;
--查询多个基表的视图 select * from v_dept_emp;
--创建基于视图的视图 create or replace view vv_emp as select ename from v_emp;
--查询基于视图的视图 select * from vv_emp;
--删除视图 drop view v_emp; drop view v_dept_emp; drop view vv_emp;
|