视图是什么

  视图是一种虚拟存在的表,不会在数据库中实际存在。相比较普通的表,有如下优势

  • 简单:使用视图的用户完全不需要关心后面对应的表的结构、关联条件和筛选条件,对用户来说已经是过滤好的复合条件的结果集
  • 安全:使用视图的用户只能访问被允许查询的结果集,对表的管理权限并不能限制到某个行某个列,但是通过视图就可以简单地实现
  • 数据独立:一旦视图的结构确定了,可以屏蔽表结构变化对用户的影响,源表增加列对视图没有影响;源表修改列名,则可以通过修改视图来解决,不会造成对访问者的影响

视图操作

  视图的操作包括创建或者修改视图、删除视图、以及查看视图定义

创建或者修改视图

  创建视图需要有CREATE VIEW的权限,并且对于查询涉及的列有SELECT权限。如果使用CREATE OR REPLACE或者ALTER修改视图,那么还需要该视图的DROP权限

创建视图的语法为:

CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

  VIEW view_name [(column_list)]

  AS select_statement

  [WITH [CASCADED | LOCAL] CHECK OPTION]

修改视图的语法为:

ALTER [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]

  VIEW view_name [(column_list)]

  AS select_statement

  [WITH [CASCADED | LOCAL] CHECK OPTION]

以northwind数据库示例中的产品表和供应商表为例创建一个视图:

MySQL的视图定义有一定的限制,如,在FROM关键字后面不能包含子查询。但可以将子查询的内容先定义成一个视图,再对该视图创建视图即可

视图更新

视图的可更新性与视图中查询的定义是有关系的。以下类型的视图是不可更新的

  • 包含以下关键字的sql语句:聚合函数、DISTINCT、GROUP BY、HAVING、UNION或者UNION ALL
  • 常量视图
  • SELECT中包含子查询
  • JOIN
  • FROM一个不能更新的视图
  • WHERE字句的子查询引用了FROM字句中的表

WITH [CASCADED | LOCAL] CHECK OPTION 决定了是否允许更新数据使记录不再满足视图的条件

  • LOCAL 只要满足本视图的条件就可以更新
  • CASCADED 则必须满足所有针对该视图的所有视图的条件才可以更新,默认值为CASCADED

查看视图

在目前的MySQL版本中,已摒弃了使用SHOW VIEWS查看视图的方法,使用SHOW TABLES不仅可以显示表,同时也可显示视图

例如,重新创建一个"产品_供应商_view"视图,并且使用SHOW TABLES查看

CREATE OR REPLACE VIEW 产品_供应商_view AS
SELECT `产品`.`产品ID`, `产品`.`产品名称`, `产品`.`单位数量`, `供应商`.`公司名称`, `供应商`.`城市`
FROM `产品`, `供应商`
WHERE `产品`.`供应商ID` = `供应商`.`供应商ID`

使用SHOW TABLES查看结果:

使用SHOW TABLE STATUS也可查看视图的信息

SHOW TABLE STATUS LIKE '产品_供应商_view' \G

查询定义视图的语句

视图数据查询

视图"产品_供应商_view"的数据结构如图所示

现在通过视图查询出一些数据

也可以使用GROUP BY等条件限制查询

视图数据修改

使用UPDATE语句可对视图中的数据进行修改。如


可以看到,视图中的第一条记录中的产品名称已变为"果粒橙",那么视图中的数据改变了,源表中的数据是不是也改变了呢?

事实上源表中的数据也发生了变化

视图数据删除

既然视图中的数据可以修改,而且源表也随之变化。那么,如果删除视图中的数据,源表会如何变化呢

由于此视图是由产品表和供应商连接查询而创建的,所以为了保证数据的完整性,是不能够删除视图中的记录

删除视图

用户可以一次删除一个或多个视图,但要求用户必须有该视图的DROP权限

语法:DROP VIEW [IF EXISTS] view_name [, view_name]...[RESTRICT | CASCADE]

例如,要删除上文中创建的视图"产品_供应商_view"

此时,视图"产品_供应商_view"已被删除

MySQL视图了解的更多相关文章

  1. Mysql 视图 游标 触发器 存储过程 事务

    Mysql 视图 触发器 存储过程 游标 游标是从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中 ...

  2. Mysql视图的作用及其性能分析

    定义:视图是从一个或几个基本表导出的表,它与基本表不同,是一个虚表. 作用: 1.简化操作,不用进行多表查询. 2.当不同种类的用用户共享同一个数据库时,非常灵活,(用户以不同的 方式看待同一数据. ...

  3. MYSQL视图的学习笔记

    MYSQL视图的学习笔记,学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆 课程笔记的综合. 视图及图形化工具   1.       视图的定义 视图就是从一个或多个表中,导出来的表,是一个虚 ...

  4. 深入解析MySQL视图view

    阅读目录---深入解析MySQL视图view 创建视图 查看视图 视图的更改 create or replace view alter DML drop 使用with check option约束 嵌 ...

  5. MySQL视图view/存储过程和函数的使用

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #454545 } p. ...

  6. MySQL视图更新

    昨天在写美团2019秋招笔试题的时候遇到了关于视图是否能更新的问题,突然感觉这个问题之前复习的时候重点关注过,但是却又想不全.今天特地搜了一些资料总结一下.本文主要说明视图的更新限制,如需关于视图的更 ...

  7. 一个MySQL视图的优化过程

    1.需要优化的sql 最近做一个基于.net mvc和MySQL的仓储系统的优化工作,遇到了一个执行特别慢的SQL语句,经过一番折腾,终于搞定啦,分享一下过程.问题就是下面这个家伙: create o ...

  8. mysql视图和临时表的区别

    视图 视图是由从数据库的基本表中选出来的数据组成的逻辑窗口,它与基本表不同的是,视图是一个虚表.数据库中只存放视图的定义,而不存放视图包含的数据,这些数据仍存放在原来的基表中.所以基表中的数据如果发生 ...

  9. MySQL视图(view)

    一.基本概念 视图是一个虚拟表,是sql的查询结果,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据,在使用视图时动态生成.视图的数据变化会影响到基表,基表的数据变化也会影响到视图 ...

  10. 11.Mysql视图

    11.视图11.1 什么是视图 视图view是一张虚拟表,它不存储数据,数据仍在表里,视图由一条查询表的select语句创建,视图只存储select语句. 可以将复杂的查询语句封装成视图,用户可以从视 ...

随机推荐

  1. 使用docker-compose搭建AspNetCore开发环境

    1 使用docker-compose搭建开发环境 我们的目标很简单:使用docker-compose把若干个docker容器组合起来就成了. 首先使用Nginx代理所有的Web程序,这样只需要在主机上 ...

  2. day4作业小代码练习

    登录模块: 我们无论上那个网站,经常遇到这样的情况,让我们登录这个网站,流程图如下: 思路: 1.当我们登录网站的时候,我们首先会输入用户名,这个时候,有些网站会提醒我们用户名是否存在,如果我们输入的 ...

  3. JVM入门——运行时数据区

    这张图我相信基本上对JVM有点接触的都应该很熟悉,可以说这是JVM入门的第一课.其中的“堆”和“虚拟机栈(栈)”更是耳熟能详.下面将围绕这张图对JVM的运行时数据区做一个简单介绍. 程序计数器(Pro ...

  4. Udp实现消息的发送和接收、以及图片的上传

    //Udp实现消息的发送和接收 import java.io.IOException; import java.net.DatagramPacket; import java.net.Datagram ...

  5. [Hadoop源码系列] FairScheduler分配申请和分配container的过程

    1.如何申请资源 1.1 如何启动AM并申请资源 1.1.1 如何启动AM val yarnClient = YarnClient.createYarnClient setupCredentials( ...

  6. Luogu 1090 合并果子(贪心,优先队列,STL运用)

    Luogu 1090 合并果子(贪心,优先队列,STL运用) Description 在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每 ...

  7. kali ssh服务连接问题,无法远程管理

    1.修改sshd_config文件,命令为:vi /etc/ssh/sshd_config 2.将#PasswordAuthentication no的注释去掉,并且将NO修改为YES 3.将#Per ...

  8. Swift语法初见

    Swift语法初见 http://c.biancheng.net/cpp/html/2424.html 类型的声明: let implicitInteger = 70 let implicitDoub ...

  9. django MVC模式 数据库的操作mysql

    介绍:本节课我们继续学习djangoWEB框架的开发,这节课主要是学习如何访问数据库,django如何自动为我们创建好表结构等相关内容. 1.首先我们打开settings.py找到DATABASES关 ...

  10. JavaScript中的几种继承方式对比

    转自:http://blog.csdn.net/kkkkkxiaofei/article/details/46474069 从’严格’意义上说,JavaScript并不是一门真正的面向对象语言.这种说 ...