SQL之视图的使用

视图是一张虚拟的表,是一个表的部分或者几个联结表的部分。它本身是没有数据的。一个重要的功能是为了方便查询。
举个例子。
利用视图简化复杂的联结。
如果我们经常查询的数据需要联结几个表。利用创建视图,就可以不再需要写复杂的联结语句。不然每次查询数据都需要写复杂的联结语句。

CREATE VIEW view AS
SELECT name, id,price
FROM table1,table2,table3
WHERE table1.id=table2.id AND table2.num=table3.num;
#创建视图之后,再查询数据只需要在视图中查询
SELECT name,id ,price
FROM view
WHERE id='0001';

DESC view;查看视图结构
再比如如果经常需要某种特定格式的数据返回,就可以先创建这种视图,以后直接用这种视图查询就行。方便SQL语句的书写。

上面说的都是查询,那么视图是否可以修改呢?
这个不好说,如果是一个表的视图可能可以修改,多个表联结的视图不行,如果视图中包含函数等操作不行,这些规定每种数据库系统都不一致。因为修改的话,就涉及到数据会重写到真正的表中,这种行为是危险的。

视图是否可以嵌套呢?可以,但是多层嵌套会使性能下降,谨慎使用。

另外,视图还有一个重要的优点就是:安全性和独立性
因为视图和底层表是分开的,所以系统可以给不同用户不同的视图,也就是说不同员工权限不一样,那么能看到的数据就不一样,符合现实需求。视图不能修改也可以保证原始数据不被随意篡改。
DROP VIEW 视图名可以删除不需要的视图。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值