mysql with as_mysql数据库学习(第十六篇)- 视图
视图
视图的行和列来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。
创建视图
Create view 视图名字 as ( 单表 or 多表 or 视图)
Create / Replace [algorithm = {undefined | merge | temptable }] view 视图名字 [(column_list)] as ( 单表 or 多表 or 视图) [with [cascaded | local ] check option ]
视图基表有多张时,注意字段名不能重复!
查看视图
Show tables ; -- 可以看到视图
Desc 视图名称; -- 可以看到视图结构(字段)
Show create table 视图名称; -- 可以查看到创建视图语句
Show create view 视图名称; -- 可以查看到创建视图语句
使用视图
当做表进行查询就行了
修改视图
删除视图
Drop view 视图名称;
Drop table 视图名称; -- 不能是table这样删除,否则报错(已测过)
视图的限制
1、 Mysql的视图在from 关键字后面不能包含子查询。
解决方案:可以先将子查询的内容先定义成一个视图,然后对该视图再创建视图就可以实现类似的功能了。
2、 视图的可更新性和视图中查询的定义有关系,有以下类型的视图是不可更新的
①:包含以下关键字的sql语句:聚合函数(sum,min,max,count等等)、distinct、group by、 having、 union 、 或者union all 。
②:常量视图。
例如:create or replace view view_pi as select 3.1415926 as pi ;
③:select 中包含子查询
④:join
⑤:from一个不能更新的视图
⑥:where子句的子查询引用了from子句中的表。
With [cascaded | local ] check option 决定了是否允许更新数据使记录不再满足视图的条件。
Local:只要满足本视图的条件就可以更新;
Cascaded:必须满足所有针对该视图的所有视图的条件才可以更新。
没有指定的话,默认是cascaded 。
1、 Create or replace view payment_view as select payment_id , amount from payment where amount < 10 with check option ;
2、 Create or replace view payment_view2 as select payment_id , amount from payment_view where amount >5 with local check option ;
3、 Create or replace view payment_view3 as select payment_id , amount from payment_view where amount >5 with cascaded check option ;
修改视图:
4、 Update payment_view2 set amount = 10 where payment_id = 3; --修改成功
5、 Update payment_view3 set amount = 10 where payment_id = 3; --修改失败。
Payment_view2 是with local check option 的,所以满足本视图的条件就可以更新。
但是payment_view3 是 with cascaded check option 的,必须满足针对该视图的所有视图才可以更新,因为更新后记录不再满足payment_view 的条件,所以更新操作提示错误退出。
视图的优势
简单: 使用视图的用户完全不需要关心后面对应的表的结构,关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集。
安全: 使用视图的用户只能访问他们被允许查询的结果集,对表的权限管理并不能限制到某个行某个列,但是通过视图就可以简单的实现。
数据独立: 一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响。
视图意义
视图数据操作
新增数据
删除数据
1. 多表视图不能删除(一般说的多表是连接多张表)
2. 单表视图可以删除
更改数据
多表视图和单表视图都可以修改数据,
视图本身只有结构,没有数据,但是他能够修改基表的数据。
前提是,他只能修改那些视图中出现的数据,那些基表存在,而视图中没有出现的数据,他根据猜测而想修改的是无效的,不起作用的。因为,他只能修改视图中出现的数据!!
更新限制
视图算法
五子句:order by; group by; having ; where ;limit;
mysql with as_mysql数据库学习(第十六篇)- 视图相关推荐
- mysql数据库和表的关系_MySQL数据库学习【第六篇】表与表之间的关系
表1 foreign key 表2 则表1的多条记录对应表2的一条记录,即多对一 利用foreign key的原理我们可以制作两张表的多对多,一对一关系 多对多: 表1的多条记录可以对应表2的一条记录 ...
- Python学习第十六篇——异常处理
在实际中,很多时候时候,我们并不能保证我们所写的程序是完美的.比如我们程序的本意是:用户在输入框内输入数字,并进行后续数学运算,即使我们提醒了用户需要输入数字而不是文本,但是有时会无意或者恶意输入字符 ...
- MySQL数据库学习日志(六):索引和视图
MySQL数据库学习日志(六):索引和视图 MySQL数据库学习日志(六):索引和视图 索引 (一)索引概述 (二)优缺点 (三)分类 1. 按照底层实现的方式 2. 按照功能划分 普通索引 唯一索引 ...
- Java学习系列(十六)Java面向对象之基于TCP协议的网络通信
TCP/IP的网络分层模型:应用层(HTTP/FTP/SMTP/POPS...),传输层(TCP协议),网络层(IP协议,负责为网络上节点分配唯一标识),物理层+数据链路层). IP地址用于标识网络中 ...
- Java基础学习——第十六章 Java8新特性
Java基础学习--第十六章 Java8 新特性 Java8(JDK8.0)较 JDK7.0 有很多变化或者说是优化,比如 interface 里可以有静态方法和默认方法,并且可以有方法体,这一点就颠 ...
- java监听数据库操作_第十六篇——JDBC操作数据库之监听器
JavaWeb应用中,很多的地方都和session有关.因此session相关的事件监听器,在日常工作中非常有用. 有时候我们需要统计当前在线的人数和访问人数总数,此时就可以使用监听器技术来很简单的实 ...
- 花书+吴恩达深度学习(十六)序列模型之双向循环网络 BRNN 和深度循环网络 Deep RNN
目录 0. 前言 1. 双向循环网络 BRNN(Bidirectional RNN) 2. 深度循环网络 Deep RNN 如果这篇文章对你有一点小小的帮助,请给个关注,点个赞喔~我会非常开心的~ 花 ...
- JavaScript学习(十六)—实现购物车加减数量,计算总金额
JavaScript学习(十六)-实现购物车加减数量,计算总金额 代码如下: <table border="2" cellspacing="0" soli ...
- 学习笔记:CentOS7学习之十六:LVM管理和ssm存储管理器使用
目录 学习笔记:CentOS7学习之十六:LVM管理和ssm存储管理器使用 16.1 LVM的工作原理 16.1.1 LVM常用术语 16.1.2 LVM优点 16.2 创建LVM的基本步骤 16.2 ...
最新文章
- ubuntu 创建github公钥
- Python中下划线---完全解读
- 分数阶simulink工具箱_CCDC 2021特别专题:分数阶微积分与分数阶系统
- 【原创】Ajax的用法总结
- AsyncHttpClient的连接池使用逻辑
- python如何对一个属性或方法进行封装_python 类、对象、方法、属性
- LaunchScreen原理
- [APIO2011] 方格染色
- request中getParameter和getAttribute的区别
- python3 selenium 点击_python3 selenium使用
- 安装fusionPBX
- 换回了WINDOWS7
- LIN总线、CAN总线、FlexRay总线和MOST总线
- 当你觉得焦虑,烦躁的时候怎么办?
- 为什么单线程的Redis能这么快?
- git pull 出现 from the remote, but no such ref was fetched 已解决
- MySQL批量导入Excel数据
- 模式对象和用户权限管理
- python修改列表元素_python 3 基础之列表和列表添加元素、修改元素、查找元素、删除元素、排序、嵌套、取最值...
- 泵机在线监测如此简单?后台数据观察一目了然