欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Oracle数据库视图的概念、语法及操作讲解

程序员文章站 2024-02-05 16:53:52
概念: 视图是由一个或者多个表组成的虚拟表;那些用于产生视图的表叫做该视图的基表。视图不占用物理空间,这个也是相对概念,因为试图本身的定义语句还是要存储在数据字典里。视图只有逻辑定...

概念: 视图是由一个或者多个表组成的虚拟表;那些用于产生视图的表叫做该视图的基表。视图不占用物理空间,这个也是相对概念,因为试图本身的定义语句还是要存储在数据字典里。视图只有逻辑定义。每次使用的时候只是重新执行SQL。一个视图也可以从另一个视图中产生。视图没有存储真正的数据,真正的数据还是存储在基表中。一般出于对基本的安全性和常用的查询语句会激励视图;并一般情况下不对视图进行新增、更新操作。

语法:

    创建视图:CREATE [OR REPLACE] VIEW <view_name> AS <SELECT 语句>;

    删除视图:DROP VIEW <view_name>;

视图操作:

授予czw用户创建视图的权限: Grant create view to czw;

登录czw,创建视图:create or replace view v_emp as select empno,ename from emp;

通过视图查询数据:select * fromv_emp;

通过视图视图添加数据,需要保证基表的其他数据项可以为空:insert into v_emp(empno,ename) values(3333,'czw3');

通过视图修改数据:update v_emp set ename='陈小帅' 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;