视图

视图的行和列来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。

创建视图

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数据库学习(第十六篇)- 视图相关推荐

  1. mysql数据库和表的关系_MySQL数据库学习【第六篇】表与表之间的关系

    表1 foreign key 表2 则表1的多条记录对应表2的一条记录,即多对一 利用foreign key的原理我们可以制作两张表的多对多,一对一关系 多对多: 表1的多条记录可以对应表2的一条记录 ...

  2. Python学习第十六篇——异常处理

    在实际中,很多时候时候,我们并不能保证我们所写的程序是完美的.比如我们程序的本意是:用户在输入框内输入数字,并进行后续数学运算,即使我们提醒了用户需要输入数字而不是文本,但是有时会无意或者恶意输入字符 ...

  3. MySQL数据库学习日志(六):索引和视图

    MySQL数据库学习日志(六):索引和视图 MySQL数据库学习日志(六):索引和视图 索引 (一)索引概述 (二)优缺点 (三)分类 1. 按照底层实现的方式 2. 按照功能划分 普通索引 唯一索引 ...

  4. Java学习系列(十六)Java面向对象之基于TCP协议的网络通信

    TCP/IP的网络分层模型:应用层(HTTP/FTP/SMTP/POPS...),传输层(TCP协议),网络层(IP协议,负责为网络上节点分配唯一标识),物理层+数据链路层). IP地址用于标识网络中 ...

  5. Java基础学习——第十六章 Java8新特性

    Java基础学习--第十六章 Java8 新特性 Java8(JDK8.0)较 JDK7.0 有很多变化或者说是优化,比如 interface 里可以有静态方法和默认方法,并且可以有方法体,这一点就颠 ...

  6. java监听数据库操作_第十六篇——JDBC操作数据库之监听器

    JavaWeb应用中,很多的地方都和session有关.因此session相关的事件监听器,在日常工作中非常有用. 有时候我们需要统计当前在线的人数和访问人数总数,此时就可以使用监听器技术来很简单的实 ...

  7. 花书+吴恩达深度学习(十六)序列模型之双向循环网络 BRNN 和深度循环网络 Deep RNN

    目录 0. 前言 1. 双向循环网络 BRNN(Bidirectional RNN) 2. 深度循环网络 Deep RNN 如果这篇文章对你有一点小小的帮助,请给个关注,点个赞喔~我会非常开心的~ 花 ...

  8. JavaScript学习(十六)—实现购物车加减数量,计算总金额

    JavaScript学习(十六)-实现购物车加减数量,计算总金额 代码如下: <table border="2" cellspacing="0" soli ...

  9. 学习笔记:CentOS7学习之十六:LVM管理和ssm存储管理器使用

    目录 学习笔记:CentOS7学习之十六:LVM管理和ssm存储管理器使用 16.1 LVM的工作原理 16.1.1 LVM常用术语 16.1.2 LVM优点 16.2 创建LVM的基本步骤 16.2 ...

最新文章

  1. ubuntu 创建github公钥
  2. Python中下划线---完全解读
  3. 分数阶simulink工具箱_CCDC 2021特别专题:分数阶微积分与分数阶系统
  4. 【原创】Ajax的用法总结
  5. AsyncHttpClient的连接池使用逻辑
  6. python如何对一个属性或方法进行封装_python 类、对象、方法、属性
  7. LaunchScreen原理
  8. [APIO2011] 方格染色
  9. request中getParameter和getAttribute的区别
  10. python3 selenium 点击_python3 selenium使用
  11. 安装fusionPBX
  12. 换回了WINDOWS7
  13. LIN总线、CAN总线、FlexRay总线和MOST总线
  14. 当你觉得焦虑,烦躁的时候怎么办?
  15. 为什么单线程的Redis能这么快?
  16. git pull 出现 from the remote, but no such ref was fetched 已解决
  17. MySQL批量导入Excel数据
  18. 模式对象和用户权限管理
  19. python修改列表元素_python 3 基础之列表和列表添加元素、修改元素、查找元素、删除元素、排序、嵌套、取最值...
  20. 泵机在线监测如此简单?后台数据观察一目了然

热门文章

  1. day002-HTML知识点总结:浏览器兼容性之指定IE浏览器使用chrome内核渲染页面
  2. 基于mjpg-streamer网络视频服务器移植
  3. mvc3 之三 符号列表
  4. 功能实现了软件就做好了吗?
  5. SQL Server服务器名称填写IP不能访问问题解决
  6. 解决Vue刷新一瞬间出现样式未加载完或者出现Vue代码问题
  7. 多线程下ArrayList类线程不安全的解决方法及原理
  8. iscroll动态加载数据完美解决方案
  9. 解决SVN 每次操作都需要重输入用户名密码问题
  10. nginx配置解决vue单页面打包文件大,首次加载慢的问题