MySQL-视图(VIEW)

文章目录

    • 1. 什么是视图?
    • 2. 视图 VS 数据表
    • 3. 视图的优点
    • 4. 视图相关语法
      • 4.1 创建视图
      • 4.2 查看视图
      • 4.3 修改视图
      • 4.4 删除视图
      • 4.5 检查选项
    • 5. 案例
    • 6. 注意事项

1. 什么是视图?

  • MySQL 视图( View)是一种虚拟存在的表,同真实表一样,视图也由列和行构成,但视图并不实际存在于数据库中。行和列的数据来自于定义视图的查询中所使用的表,并且还是在使用视图时动态生成的一旦真实表中的数据发生改变,显示在视图中的数据也会发生改变

2. 视图 VS 数据表

  • 视图并不同于数据表,它们的区别在于以下几点

    1. 视图不是数据库中真实的表,而是一张虚拟表,其结构和数据是建立在对数据中真实表的查询基础上的。
    2. 存储在数据库中的查询操作 SQL 语句定义了视图的内容,列数据和行数据来自于视图查询所引用的实际表,引用视图时动态生成这些数据。
    3. 视图没有实际的物理记录,不是以数据集的形式存储在数据库中的,它所对应的数据实际上是存储在视图所引用的真实表中的。
    4. 视图是数据的窗口,而表是内容。表是实际数据的存放单位,而视图只是以不同的显示方式展示数据,其数据来源还是实际表
    5. 视图是查看数据表的一种方法,可以查询数据表中某些字段构成的数据,只是一些 SQL 语句的集合。从安全的角度来看,视图的数据安全性更高使用视图的用户不接触数据表,不知道表结构。
    6. 视图的建立和删除只影响视图本身,不影响对应的基本表

3. 视图的优点

  1. 定制用户数据,聚焦特定的数据

    • 在实际的应用过程中,不同的用户可能对不同的数据有不同的要求。例如,当数据库同时存在时,如学生基本信息表、课程表和教师信息表等多种表同时存在时,可以根据需求让不同的用户使用各自的数据。学生查看修改自己基本信息的视图,安排程人员查看修改课程表和教师信息的视图,教师查看学生信息和课程信息表的视图。
  2. 简化数据操作

    • 在使用查询时,很多时候要使用聚合函数,同时还要显示其他字段的信息, 可能还需要关联到其他表,语句可能会很长,如果这个动作频繁发生的话,可以创建视图来简化操作。
  3. 提高数据的安全性

    • 视图是虚拟的,物理上是不存在的。可以只授予用户视图的权限,而不具体指定使用表的权限,来保护基础数据的安
      全。
  4. 共享所需数据

    • 通过使用视图,每个用户不必都定义和存储自己所需的数据,可以共享数据库中的数据,同样的数据只需要存储一次。
  5. 更改数据格式

    • 通过使用视图,可以重新格式化检索出的数据,并组织输出到其他应用程序中。
  6. 重用 SQL 语句

    • 视图提供的是对查询操作的封装,本身不包含数据,所呈现的数据是根据视图定义从基础表中检索出来的,如果基础表的数据新增或删除,视图呈现的也是更新后的数据。视图定义后,编写完所需的查询,可以方便地重用该视图。

4. 视图相关语法

4.1 创建视图

  • 创建视图的语法如下:

    CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH [CASCADED | LOCAL ] CHECK OPTION ]
    
  • 默认情况下,创建的视图和基本表的字段是一样的,也可以通过指定视图字段的名称来创建视图

    CREATE VIEW v_students_info (s_id,s_name,d_id,s_age,s_sex,s_height,s_date)
    AS SELECT id,name,dept_id,age,sex,height,login_date
    FROM tb_students_info;
    
  • 注意事项:

    1. WITH CHECK OPTION 的意思是,修改视图时,检查插入的数据是否符合 WHERE 设置的条件。
    2. SELECT 语句不能包含 FROM 子句中的子查询
    3. SELECT 语句不能引用系统或用户变量。
    4. 用户除了拥有 CREATE VIEW 权限外,还具有操作中涉及的基础表和其他视图的相关权限。

4.2 查看视图

  • 查看视图的字段信息:

    DESC 视图名;
    
  • 查看视图的详细信息:

    SHOW CREATE VIEW 视图名;
    

4.3 修改视图

  • 可以使用 ALTER VIEW 语句来对已有的视图进行修改。语法格式如下:

    ALTER VIEW <视图名> AS