🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
视图就是一张虚表,只存储表结构,并不存储表真实数据,数据是在查询时动态生成的。 使用视图的好处: 更方便,简化了操作,我们只需要使用视图获取数据,无需知道怎么处理的; 更安全,我们只能访问到视图就能得到数据,无需访问原表; 降低耦合性,表结构更改时,只需要调整下视图,无需更改应用程序代码。 1、创建视图 create view v1 as select * from aa; create view v1(id,name) as select id,name from aa; create or replace view v1 as select 语句; #视图已存在时创建 完整语法:create [algorithm = undefined/merge/temptable] view 视图名 as 查询语句 [with [cascaded/local] check option]; 通过 algorithm 可以选取相应的算法来从基表展示数据: (1) merge:把从视图取数据的 SQL 改变成从原表取数据的 SQL; (2) temptable:将视图的结果放置到临时表中,然后使用它执行语句,此时视图不可更新; (3) undefined:MySQL 自动选择。 2、查看视图 show tables; desc v1; show create view v1\G; show status like [from db_name] [like tbl_name]; select * from v1; 3、更新视图 update v1 set name = 'shang' where id = 1; 以下类型的视图是不能更新的: (1) 包含聚合函数、distinct、group by、having、union、union all; (2) 常量视图; (3) select 包含子查询; (4) 包含连接操作; (5) from 一个不能更新的视图; (6) where 子句的子查询引用了 from 子句中的表。 4、插入视图 insert into v1 select value1,value2; 关键字 with check option 在插入时进行检查,满足视图条件才允许操作,否则拒绝,比如: create view v2(name,age) as select name,age from info where age < 20 with check option; insert into v2 select 'shang',24; #拒绝操作,因为不满足视图条件(age < 20) 其他参数:with [local/cascaded] check option local:只需满足本视图条件; cascaded:默认值,需满足所有视图条件(即在视图派生视图时,满足每个视图条件); 5、修改视图 alter view v1 ...; 6、删除视图 drop [if exists] view v1,v2,...; 总结: (1) 视图更多的是提供了一个中间层的功能,来屏蔽一些我们的操作。 (2) MySQL 的视图功能还是比较弱的,比如说不支持物化视图等等。