Oracle视图简介

本文详细介绍SQL中视图的创建方法,包括使用force、noforce、orreplace等选项的含义,以及withcheckoption和withreadonly子句的作用。同时,探讨了在视图上执行DML操作的影响,如插入、更新和删除操作,并解释了如何删除视图。

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

一,语法:
create [force|noforce][or replace] view 视图名称[(别名1,别名2)]
as
子查询[with check option [constraint 约束名称] ] [with read only];
force:表示要创建视图的表不存在也可以创建视图
noforce:(默认)表示要创建视图的表必须存在,否则无法创建
or replace:表示视图的替换,如果创建的视图不存在则创建新的,若已存在,则将其替换
with check option 子句:用来保证视图创建的条件不被更新
with read only 子句:设置视图为只读
实例:创建一个简单查工资的视图

create or replace view v_forsal
as
select * from emp where sal>2000;

二,在视图上执行DML操作:(视图最好只进行查询操作)
简单视图更新的时候会直接影响到实体表数据(单表映射数据)
创建简单视图:

create or replace view v_deptno
as
select empno,ename,job,sal from emp where deptno=10;


1,新增操作

insert into v_deptno(empno,ename,job,sal) values(123456,'bigboss','boss',10000)


此时插入数据,由于视图查询的不是*所以插入也只会从插入部分数据,没有映射到视图之中的列,都会被null填充,若列约束为非空,则会报错
2,修改操作

update v_deptno set ename = 'xiao',job = 'yanyuan',sal = 1500 where empno = 123456;


3,删除操作

delete from v_deptno where empno = 123456;


复杂视图无法更新(多表映射)--可运用触发器实现

三,删除视图
drop view 视图名称
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值