岁月如歌——MySQL视图初探索

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Baronrothschlid/article/details/81901513

 

最近ITOO教务的项目需要给MySQL去视图,既然接到了这个任务,那当然要了解一下啦,于是就给自己补补课,看看到底什么是视图。

什么是视图:

视图是一种虚拟存在的表,是一个逻辑表,本身并不包含和存储数据。而是按照指定的方式进行查询,作为一个select语句保存在数据字典中的。

通过视图,可以展现基表的部分数据;视图数据来自定义视图的查询中使用的表,使用视图动态生成。

基表:用来创建视图的表叫做基表base table。

 

视图的优点:

1.简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。

2.安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。

3.数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。

扫描二维码关注公众号,回复: 3751388 查看本文章

 

视图的缺点:

现在要画重点了,视图的缺点也是就是我们这次要花大力气去视图的原因:

1.性能:从数据库视图查询数据可能会很慢,特别是如果视图是基于其他视图创建的。

2.表依赖关系:将根据数据库的基础表创建一个视图。每当更改与其相关联的表的结构时,都必须更改视图。

 

视图的基本语法:

操作指令 代码
创建视图 CREATE VIEW 视图名(列1,列2...) AS SELECT (列1,列2...) FROM ...;
使用视图 当成表使用就好
修改视图 CREATE OR REPLACE VIEW 视图名 AS SELECT [...] FROM [...];
查看数据库已有视图 >SHOW TABLES [like...];(可以使用模糊查找)
查看视图详情 DESC 视图名或者SHOW FIELDS FROM 视图名
视图条件限制 [WITH CHECK OPTION]

猜你喜欢

转载自blog.csdn.net/Baronrothschlid/article/details/81901513