视图的简介
视图:view 是一种有结构(有行有列)但是没有结果(结构中不真实存放数据)的虚拟表,虚拟表的结构来源不是自己定义,而是从对应的基表中产生的(视图的数据来源)
视图的意义
1. 视图可以节省SQL语句: 将一条复杂的查询语句使用视图进行保存: 以后可以直接对视图进行操作
2. 数据安全: 视图操作是主要针对查询的, 如果对视图结构进行处理(删除), 不会影响基表数据(相对安全).
3. 视图往往是在大项目中使用, 而且是多系统使用: 可以对外提供有用的数据, 但是隐藏关键(无用)的数据: 数据安全
4. 视图可以对外提供友好型: 不同的视图提供不同的数据, 对外好像专门设计
5. 视图可以更好(容易)的进行权限控制
创建视图
基本语法 create view 视图名字 as select 语句,select语句可以是普通查询,可以是连接查询,可以是联合查询,也可以是子查询
创建单表视图:基表只有一个
单表视图创建多表视图:基表至少得有2个以上
多表视图查看视图
视图相当于一张虚拟表,适用于表的所有查看方式都适用于视图:show tables like/desc 视图名字
查看视图查看视图的创建语句 show create table/view 视图名字;
show table查看方法 show view查看方法视图创建成功后会再对应的数据库文件夹下创建一个对应的结构文件:frm文件
目录中对应的frm文件视图的使用
使用视图主要是为了查询:将视图当做表一样查询即可
查询my_v1结果 查询多表视图my_v2结果视图的执行:其实本质就是封装的select语句
修改视图
视图本身不可以修改,但是视图的来源可以修改
修改视图:修改视图本身的来源语句(select语句)
Alter view 视图名字 as 新的 select 语句
视图修改之前 视图修改之后少了一个`number`字段删除视图
删除视图视图的数据操作
视图可以进行数据写操作:但是有很多限制
将数据直接在视图上进行操作
新增数据
数据新增就是直接对视图进行数据新增
1:多表视图不能新增数据
多表视图的新增数据2:可以向单表视图插入数据:但是视图中包含的字段必须有,基表中所有不能为空的字段(或者没有默认值)字段
视图新增数据:单表需注意我这里相对于基表中少了一个`number`字段但是能插入成功的原因是我默认了基表中的`number`允许为空,否则是插入不进去会报错的
单表视图的查询结果 单表视图基表的查询结果,注意number为NULL删除数据
多表视图不能删除数据
视图多表删除报错单表视图可以删除数据
单表视图删除数据成功 单表视图删除结果查看更新数据
理论上不论是单表视图还是多表视图都可以更新数据
多表视图更新数据前 多表视图更新数据后的结果 单表视图更新数据前 单表视图更新数据后更新限制:
with check option, 如果对视图在新增的时候,限定了某个字段有限制: 那么在对视图进行数据更新操作时,系统会进行验证: 要保证更新之后,数据依然可以被实体查询出来,否则不让更新.
创建一个更新字段限制的视图
表视视图的数据来源都是年龄大于30岁:where age > 30 决定 不能将已经得到的数据改成小于30 的 将已经得到的数据改成小于30的会报错修改合格数据
数据修改之前 数据修改之后视图算法
视图算法: 系统对视图以及外部查询视图的Select语句的一种解析方式.
视图算法分为三种
Undefined: 未定义(默认的), 这不是一种实际使用算法, 是一种推卸责任的算法: 告诉系统,视图没有定义算法, 系统自己看着办
Temptable: 临时表算法: 系统应该先执行视图的select语句,后执行外部查询语句
Merge: 合并算法: 系统应该先将视图对应的select语句与外部查询视图的select语句进行合并,然后执行(效率高: 常态)
算法指定: 在创建视图的时候
Create algorithm = 指定算法 view 视图名字 as select语句;
查询所有,升高降序排列视图算法选择:
如果视图的select语句中会包含一个查询子句(五子句), 而且很有可能顺序比外部的查询语句要靠后, 一定要使用算法temptable,其他情况可以不用指定(默认即可).
网友评论