前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL视图示例

MySQL视图示例

作者头像
Mandy的名字被占用了
发布2019-07-22 16:08:20
7660
发布2019-07-22 16:08:20
举报

什么是视图?视图是干什么用的?

视图(view)是一种虚拟存在的表,是一个逻辑表,本身并不包含数据。作为一个select语句保存在数据字典中的。 通过视图,可以展现基表的部分数据;视图数据来自定义视图的查询中使用的表,使用视图动态生成。基表:用来创建视图的表叫做基表base table.

为什么要使用视图?

. 简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。 . 安全:使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。 . 数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。

如何创建视图

代码语言:javascript
复制
CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]

. OR REPLACE:表示替换已有视图 . ALGORITHM:表示视图选择算法,默认算法是UNDEFINED(未定义的):MySQL自动选择要使用的算法 ;merge合并;temptable临时表 . columnlist:视图字段,显示指定视图列名,要求视图名后面的列的数量必须匹配select子句中的列的数量。 . selectstatement:表示select语句 . [WITH [CASCADED | LOCAL] CHECK OPTION]:表示视图在更新时保证在视图的权限范围之内 . cascade是默认值,表示更新视图的时候,要满足视图和表的相关条件 . local表示更新视图的时候,要满足该视图定义的一个条件即可推荐使用WHIT [CASCADED|LOCAL] CHECK OPTION选项,可以保证数据的安全性.

查看视图内部结构

代码语言:javascript
复制
show create view 视图名;

删除视图

代码语言:javascript
复制
drop view 视图名;

如何查看库中的视图

. 第一种方式

代码语言:javascript
复制
mysql> show table status where comment='view';

(说明:Mysql5.1支持视图,视图被看作一种抽象表,因此显示视图状态的语句与显示表状态的语句相同,只是在comment列中以‘view’区分) . 第二种方式

代码语言:javascript
复制
mysql> select * from information_schema.tables where
 table_schema='你当前的数据库名' and table_type='view';

(说明:这种方法通过系统表查找,效果同上,显示信息更详细。如果不能正确显示结果,可能是大小写的问题,Mysql在不同系统平台不同配置参数下的显示结果可能不同,注意这点。)

视图更新限制

. 视图中如果包含了group by、union等有关的聚合函数,此时视图是不能做更新操作的. . 视图中如果出现了关联多表的sql语句,此时修改的字段必须来源同一个基表. . 视图如果在定义的时候,使用了临时表的算法是无法进行更新操作.

视图的限制

. 视图中无法创建索引 . 视图中无法创建触发器 . 视图中不支持物化视图(不过可以自定义物化视图或者使用一个mysql管理工具实现flexview(https://github.com/greenlion/swanhart-tools),这个工具还在研究中,后期单独写一篇文章来讲解MySQL如何实现物化视图) . 无法保存视图定义的sql语句

使用演示

代码语言:javascript
复制
mysql> create view v_user
    -> as
    -> select * from user
    -> with check option;

mysql> select * from v_user;
+----+--------+-----+------+
| id | name   | age | sex  |
+----+--------+-----+------+
|  1 | 张三   |  12 | 男   |
|  2 | 小红   |  10 | 女   |
|  3 | 李倩   |  12 | 女   |
+----+--------+-----+------+
3 rows in set (0.00 sec)

mysql> show create view v_user\G;
*************************** 1. row ***************************
View: v_user
Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `v_user` AS select `user`.`id` AS `id`,`user`.`name` AS `name`,`user`.`age` AS `age`,`user`.`sex` AS `sex` from `user` WITH CASCADED CHECK OPTION
character_set_client: utf8
collation_connection: utf8_general_ci
1 row in set (0.00 sec)

mysql> drop view v_user;
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-12-16,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 卡二条的技术圈 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档