数据库 视图的理解及其使用语法

本文详细介绍了数据库视图的概念,包括视图的创建、查询、更新、删除等操作,以及基于视图的视图创建和查询。同时,文章还探讨了视图在安全性控制和常用查询语句中的应用。

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

视图

视图简介

视图是由一个或者多个表组成的虚拟表;

那些用于产生视图的表叫做该视图的基表视图不占用物理空间,这个也是相对概念,因为视图本身的定义语句还是要存储在数据字典里的。视图只有逻辑定义。每次使用的时候只是重新执行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;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值