[视图](http://ihavenolimitations.xyz/aakng/mysql/211264)
视图就是一张虚表,只存储表结构,并不存储表真实数据,数据是在查询时动态生成的。
使用视图的好处:
更方便,简化了操作,我们只需要使用视图获取数据,无需知道怎么处理的;
更安全,我们只能访问到视图就能得到数据,无需访问原表;
降低耦合性,表结构更改时,只需要调整下视图,无需更改应用程序代码。
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 的视图功能还是比较弱的,比如说不支持物化视图等等。
- 数据库
- CAP定理
- 关系模型
- 关系数据库
- NoSQL
- ODBC
- JDBC
- ODBC、JDBC和四种驱动类型
- mysql
- 安装与配置
- CentOS 7 安装 MySQL
- 优化
- 比较全面的MySQL优化参考
- 1、硬件层相关优化
- 1.1、CPU相关
- 1.2、磁盘I/O相关
- 2、系统层相关优化
- 2.1、文件系统层优化
- 2.2、其他内核参数优化
- 3、MySQL层相关优化
- 3.1、关于版本选择
- 3.2、关于最重要的参数选项调整建议
- 3.3、关于Schema设计规范及SQL使用建议
- 3.4、其他建议
- 后记
- Mysql设计与优化专题
- ER图,数据建模与数据字典
- 数据中设计中的范式与反范式
- 字段类型与合理的选择字段类型
- 表的垂直拆分和水平拆分
- 详解慢查询
- mysql的最佳索引攻略
- 高手详解SQL性能优化十条经验
- 优化SQL查询:如何写出高性能SQL语句
- MySQL索引原理及慢查询优化
- 数据库SQL优化大总结之 百万级数据库优化方案
- 数据库性能优化之SQL语句优化1
- 【重磅干货】看了此文,Oracle SQL优化文章不必再看!
- MySQL 对于千万级的大表要怎么优化?
- MySQL 数据库设计总结
- MYSQL性能优化的最佳20+条经验
- 数据操作
- 数据语句操作类型
- DCL
- 修改Mysql数据库名的5种方法
- DML
- 连接
- 连接2
- DDL
- 数据类型
- 字符集
- 表引擎
- 索引
- MySQL理解索引、添加索引的原则
- mysql建索引的几大原则
- 浅谈mysql的索引设计原则以及常见索引的区别
- 常用工具简介
- QA
- MySQL主机127.0.0.1与localhost区别总结
- 视图(view)
- 触发器
- 自定义函数和存储过程的使用
- 事务(transaction)
- 范式与反范式
- 常用函数
- MySQL 数据类型 详解
- Mysql数据库常用分库和分表方式
- 隔离级别
- 五分钟搞清楚MySQL事务隔离级别
- mysql隔离级别及事务传播
- 事务隔离级别和脏读的快速入门
- 数据库引擎中的隔离级别
- 事务隔离级别
- Innodb中的事务隔离级别和锁的关系
- MySQL 四种事务隔离级的说明
- Innodb锁机制:Next-Key Lock 浅谈
- SQL函数和存储过程的区别
- mongo
- MongoDB设置访问权限、设置用户
- redis
- ORM
- mybatis
- $ vs #
- mybatis深入理解(一)之 # 与 $ 区别以及 sql 预编译
- 电商设计
- B2C电子商务系统研发——概述篇
- B2C电子商务系统研发——商品数据模型设计
- B2C电子商务系统研发——商品模块E-R图建模
- B2C电子商务系统研发——商品SKU分析和设计(一)
- B2C电子商务系统研发——商品SKU分析和设计(二)
- 数据库命名规范--通用