Oracle视图的创建、使用以及删除操作方法大全

 更新时间:2023年12月20日 11:42:50   作者:ZimMer@柠檬  
这篇文章主要给大家介绍了关于Oracle视图的创建、使用以及删除操作方法的相关资料,视图是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改,需要的朋友可以参考下

前言

视图就是一张或多张表上的预定义查询

视图作用:减少子查询的复杂性;提高运行效率;可以仅提供视图数据,提高数据的安全性。视图以定义的方式存储在数据库中,不占用表空间。

查询视图的时候就是执行视图里封装的逻辑,逻辑里用到的表称为 基表

一、创建视图

视图的命名:通常结尾带_V

视图创建语法:

    create or replace view 视图名称_V
    as
    查询的逻辑 (select);
   -- with read only; 可以增加只读属性

二、查询、删除视图

查询视图就是查询视图中封装的sql逻辑的内容

查看视图的语法:

select * from 视图名;

删除视图的语法:

DROP VIEW 视图名_V;

三、视图的优点

  • 可以简化日常操作
  • 增加数据使用的安全性
  • 减少网络数据传输
  • 可以增加只读属性(with read only),保障数据安全

例一:简化日常的操作 --将常用的SQL封装到视图中

步骤一:创建查询视图:

create or replace view aa_v 
as 
select f.deptno 部门编号,f.dname 部门名称 ,count(e.empno) 部门人数 ,
avg(e.sal) 平均工资,max(e.sal) 最大工资,min(e.sal) 最小工资,sum(e.sal) 工资总和
from dept f
left join emp e
on f.deptno=e.deptno
group by f.deptno,f.dname
order by f.deptno;

该处使用的url网络请求的数据。

步骤二:查看视图

select * from aa_v;

例二:增加数据的安全性 --屏蔽掉私密数据(如工资,奖金)

给用户查看视图bb_v权限,不给看emp表权限;

步骤一:创建查询视图:

create or replace view bb_v 
as 
select empno,ename,job,mgr,deptno
from emp;

步骤二:查看视图

select * from bb_v;

例三:视图的修改

步骤一:创建查询视图:

create table emp_111 as select * from emp;

create or replace view cc_v 
as 
select empno,ename,job,mgr,deptno
from emp_111;

步骤二:查看视图

select * from cc_v;

步骤三:修改视图

update cc_v set deptno=50 where empno=7788;
commit; --提交

步骤四:再次查看视图

视图数据发生了改变

select * from cc_v;

查看原表中的数据,发现原表的数据也发生了改变。

select * from emp_111;

例四:视图增加只读属性,防止别人对数据进行修改

步骤一:创建查询视图:

create or replace view dd_v 
as 
select empno,ename,job,mgr,deptno
from emp_111
with read only;  --加上只读属性

步骤二:查看视图

select * from dd_v;

步骤三:尝试修改只可读视图

发现修改视图内容报错误。

update cc_v set deptno=50 where empno=7788;
commit; --提交

例五:视图当表用

步骤一:创建查询视图:

CREATE OR REPLACE  VIEW EMP_ENAME_V 
AS 
SELECT T.EMPNO
      ,T.ENAME
      ,T.DEPTNO
      ---函数返回的结果一定要给别名
      ,TO_CHAR(T.HIREDATE,'YYYY') as rz_year
FROM EMP T; --基表

步骤二:查看视图

select * from EMP_ENAME_V; --查询视图就是查询视图中封装的sql逻辑的内容;

步骤三:视图当做表进行过滤查询

SELECT * FROM EMP_ENAME_V TWHERE T.EMPNO = 7369;

例六:视图嵌套使用

步骤一:创建查询视图:

CREATE OR REPLACE VIEW EMP_DEPT_V 
AS 
SELECT T.EMPNO
      ,T.ENAME
      ,T2.DNAME
FROM EMP_ENAME_V T
INNER JOIN DEPT T2
        ON T.DEPTNO = T2.DEPTNO;

步骤二:查看视图

SELECT * FROM EMP_DEPT_V;

删除视图

DROP VIEW EMP_DEPT_V;

例七:with as 结合视图使用

步骤一:创建查询视图:

create or replace view hh_v
as
with table1 as(select * from emp where deptno=10),
     table2 as(select * from emp where deptno=20),
     table3 as(select* from dept)
     
     select e.*,f.dname,f.loc from table1 e
     inner join table3 f
     on e.deptno = f.deptno;

步骤二:查看视图

select * from hh_v;

附:如何使用Oracle创建多表视图?

vip会员内容

总结 

到此这篇关于Oracle视图的创建、使用以及删除操作方法大全的文章就介绍到这了,更多相关Oracle视图创建使用及删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle数据库数据丢失恢复的几种方法总结

    Oracle数据库数据丢失恢复的几种方法总结

    相信大家无论是开发、测试还是运维过程中,都可能会因为误操作、连错数据库、用错用户、语句条件有误等原因,导致错误删除、错误更新等问题。当你捶胸顿足或吓得腿软时,肯定希望有办法来恢复这些数据。oracle就提供了一些强大的方法或机制,可以帮到有需要的你。
    2016-12-12
  • Oracle Linux 6.8安装 mysql 5.7.17的详细教程

    Oracle Linux 6.8安装 mysql 5.7.17的详细教程

    这篇文章主要介绍了Oracle Linux 6.8安装 mysql 5.7.17的详细教程,需要的朋友可以参考下
    2017-06-06
  • Oracle用户密码含有特殊字符导致无法登陆解决方法

    Oracle用户密码含有特殊字符导致无法登陆解决方法

    在客户端上使用sqlplus用普通用户可以登录,但是system以及sys用户均无法登录,提示ORA-12154: TNS: 无法解析指定的连接标识符,本文将提供详细的解决方法,需要了解的朋友可以参考下
    2012-11-11
  • Oracle中备份表的简单sql命令语句

    Oracle中备份表的简单sql命令语句

    备份表的简单sql命令想必有黑多的新手朋友们还是会忘记的即便是老手也不例外吧,下面与大家分享下具体的sql语句,希望对你有所帮助
    2013-05-05
  • oracle查看会话锁定的所有对象代码分享

    oracle查看会话锁定的所有对象代码分享

    oracle查看会话锁定的所有对象
    2014-01-01
  • LINUX下Oracle数据导入导出的方法详解

    LINUX下Oracle数据导入导出的方法详解

    这篇文章主要介绍了LINUX下Oracle数据导入导出的方法,较为详细的分析导出工具exp及导入工具imp的具体使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-12-12
  • PLSQL环境配置详细图文步骤

    PLSQL环境配置详细图文步骤

    PL/SQL是Oracle对行业标准SQL的过程性扩展,下面这篇文章主要给大家介绍了关于PLSQL环境配置的详细图文步骤,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • 关于Oracle中SqlLoader的用法

    关于Oracle中SqlLoader的用法

    这篇文章主要介绍了关于Oracle中SqlLoader的用法,sqlldr是oracle的sql*loader工具,他可以把外部的文本格式数据导入到oracle的内部表中,适用于不同数据库之间的数据转化迁移,需要的朋友可以参考下
    2023-07-07
  • 使用Oracle命令进行数据库备份与还原

    使用Oracle命令进行数据库备份与还原

    本文详细讲解了使用Oracle命令进行数据库备份与还原的方法,文中通过示例代码介绍的非常详细。对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧<BR>
    2021-12-12
  • oracle使用存储过程将表数据以excel格式导出的操作方法

    oracle使用存储过程将表数据以excel格式导出的操作方法

    虽然目前pl/sql developer等数据库客户端软件都支持将表数据以excel格式导出,但是如果数据量大,需要等客户端加载表数据等待很久,这篇文章给大家分享oracle使用存储过程将表数据以excel格式导出的操作方法,需要的朋友可以参考下
    2024-07-07

最新评论