Oracle视图

本文深入讲解Oracle数据库中的视图概念,包括视图的定义、作用、创建与使用方法,以及如何通过视图简化复杂查询、限制数据访问和封装SQL语句。同时探讨了视图在数据操作中的限制和注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle视图

--视图就是封装了一条复杂查询的语句。
--视图是一个虚表。
--最大的优点就是简化复杂的查询。

--视图是有一个或多个表组成的数据库对象。
--这些表称为视图的基表。
1)限制对表中某些列的访问;
2)简化查询操作;
create or replace view 视图名
as
select 列名1,列名2... 
from 用户名.表名;

--1.创建视图必须要具有create view权限。
--2.select 关键字后面的列名就是视图显示的列名
--创建视图需要权限,要给scott用户授权
grant dba to scott;

--切换回scott用户创建视图
create or replace view v_emp 
as 
select * 
from emp;

--使用
select * from v_emp;

update v_emp set ename = 'smith' where empno = 7369;
commit;

--不建议通过视图对表中的数据进行修改,因为会受到很多的限制。


--查询emp
select * from emp;

--屏蔽一些敏感数据
create or replace view v_emp_no_sal 
as
select empno,ename,job,mgr,hiredate,deptno from emp; 


select * from v_emp_no_sal;

--封装复杂sql语句
--查询部门的平均工资
create or replace view v_avg_sal
as
select deptno,round(avg(sal),2) as dsal
from emp
group by deptno;

select * from v_avg_sal;

使用视图

视图的使用与表的使用是一样的。
--即视图也可以进行增删改查等操作
--注意:对视图的操作实际上就是对视图基表的操作。
例如: 往视图中添加数据,那么视图的基表中也会添加该条数据.
但是,在实际开发中很少会使用视图修改基表的数据。

删除视图

drop view 视图名;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值