ToB企服应用市场:ToB评测及商务社交产业平台

标题: MySQL数据库——MySQL创建视图(CREATE VIEW) [打印本页]

作者: 瑞星    时间: 2024-7-11 16:58
标题: MySQL数据库——MySQL创建视图(CREATE VIEW)
创建视图是指在已经存在的 MySQL 数据库表上建立视图。视图可以建立在一张表中,也可以建立在多张表中。
根本语法

可以使用 CREATE VIEW 语句来创建视图。
语法格式如下:
  1. CREATE VIEW <视图名> AS <SELECT语句>
复制代码
语法说明如下。

对于创建视图中的 SELECT 语句的指定存在以下限制:

视图界说中引用的表或视图必须存在。但是,创建完视图后,可以删除界说引用的表或视图。可使用 CHECK TABLE 语句查抄视图界说是否存在这类问题。
视图界说中允许使用 ORDER BY 语句,但是若从特定视图进行选择,而该视图使用了自己的 ORDER BY 语句,则视图界说中的 ORDER BY 将被忽略。
视图界说中不能引用 TEMPORARY 表(暂时表),不能创建 TEMPORARY 视图。
WITH CHECK OPTION 的意思是,修改视图时,查抄插入的数据是否符合 WHERE 设置的条件。
创建基于单表的视图

MySQL 可以在单个数据表上创建视图。
查察 test_db 数据库中的 tb_students_info 表的数据,如下所示:
  1. mysql> SELECT * FROM tb_students_info;
  2. +----+--------+---------+------+------+--------+------------+
  3. | id | name   | dept_id | age  | sex  | height | login_date |
  4. +----+--------+---------+------+------+--------+------------+
  5. |  1 | Dany   |       1 |   25 | F    |    160 | 2015-09-10 |
  6. |  2 | Green  |       3 |   23 | F    |    158 | 2016-10-22 |
  7. |  3 | Henry  |       2 |   23 | M    |    185 | 2015-05-31 |
  8. |  4 | Jane   |       1 |   22 | F    |    162 | 2016-12-20 |
  9. |  5 | Jim    |       1 |   24 | M    |    175 | 2016-01-15 |
  10. |  6 | John   |       2 |   21 | M    |    172 | 2015-11-11 |
  11. |  7 | Lily   |       6 |   22 | F    |    165 | 2016-02-26 |
  12. |  8 | Susan  |       4 |   23 | F    |    170 | 2015-10-01 |
  13. |  9 | Thomas |       3 |   22 | M    |    178 | 2016-06-07 |
  14. | 10 | Tom    |       4 |   23 | M    |    165 | 2016-08-05 |
  15. +----+--------+---------+------+------+--------+------------+
  16. 10 rows in set (0.00 sec)
复制代码
【实例 1】在 tb_students_info 表上创建一个名为 view_students_info 的视图,输入的 SQL 语句和执行结果如下所示:
  1. mysql> CREATE VIEW view_students_info
  2.     -> AS SELECT * FROM tb_students_info;
  3. Query OK, 0 rows affected (0.00 sec)
  4. mysql> SELECT * FROM view_students_info;
  5. +----+--------+---------+------+------+--------+------------+
  6. | id | name   | dept_id | age  | sex  | height | login_date |
  7. +----+--------+---------+------+------+--------+------------+
  8. |  1 | Dany   |       1 |   25 | F    |    160 | 2015-09-10 |
  9. |  2 | Green  |       3 |   23 | F    |    158 | 2016-10-22 |
  10. |  3 | Henry  |       2 |   23 | M    |    185 | 2015-05-31 |
  11. |  4 | Jane   |       1 |   22 | F    |    162 | 2016-12-20 |
  12. |  5 | Jim    |       1 |   24 | M    |    175 | 2016-01-15 |
  13. |  6 | John   |       2 |   21 | M    |    172 | 2015-11-11 |
  14. |  7 | Lily   |       6 |   22 | F    |    165 | 2016-02-26 |
  15. |  8 | Susan  |       4 |   23 | F    |    170 | 2015-10-01 |
  16. |  9 | Thomas |       3 |   22 | M    |    178 | 2016-06-07 |
  17. | 10 | Tom    |       4 |   23 | M    |    165 | 2016-08-05 |
  18. +----+--------+---------+------+------+--------+------------+
  19. 10 rows in set (0.04 sec)
复制代码
默认情况下,创建的视图和根本表的字段是一样的,也可以通过指定视图字段的名称来创建视图。
【实例 2】在 tb_students_info 表上创建一个名为 v_students_info 的视图,输入的 SQL 语句和执行结果如下所示:
  1. mysql> CREATE VIEW v_students_info
  2.     -> (s_id,s_name,d_id,s_age,s_sex,s_height,s_date)
  3.     -> AS SELECT id,name,dept_id,age,sex,height,login_date
  4.     -> FROM tb_students_info;
  5. Query OK, 0 rows affected (0.06 sec)
  6. mysql> SELECT * FROM v_students_info;
  7. +------+--------+------+-------+-------+----------+------------+
  8. | s_id | s_name | d_id | s_age | s_sex | s_height | s_date     |
  9. +------+--------+------+-------+-------+----------+------------+
  10. |    1 | Dany   |    1 |    24 | F     |      160 | 2015-09-10 |
  11. |    2 | Green  |    3 |    23 | F     |      158 | 2016-10-22 |
  12. |    3 | Henry  |    2 |    23 | M     |      185 | 2015-05-31 |
  13. |    4 | Jane   |    1 |    22 | F     |      162 | 2016-12-20 |
  14. |    5 | Jim    |    1 |    24 | M     |      175 | 2016-01-15 |
  15. |    6 | John   |    2 |    21 | M     |      172 | 2015-11-11 |
  16. |    7 | Lily   |    6 |    22 | F     |      165 | 2016-02-26 |
  17. |    8 | Susan  |    4 |    23 | F     |      170 | 2015-10-01 |
  18. |    9 | Thomas |    3 |    22 | M     |      178 | 2016-06-07 |
  19. |   10 | Tom    |    4 |    23 | M     |      165 | 2016-08-05 |
  20. +------+--------+------+-------+-------+----------+------------+
  21. 10 rows in set (0.01 sec)
复制代码
可以看到,view_students_info 和 v_students_info 两个视图中的字段名称不同,但是数据却相同。因此,在使用视图时,可能用户不需要相识根本表的结构,更打仗不到实际表中的数据,从而保证了数据库的安全。
创建基于多表的视图

MySQL 中也可以在两个以上的表中创建视图,使用 CREATE VIEW 语句创建。
【实例 3】在表 tb_student_info 和表 tb_departments 上创建视图 v_students_info,输入的 SQL 语句和执行结果如下所示:
  1. mysql> CREATE VIEW v_students_info
  2.     -> (s_id,s_name,d_id,s_age,s_sex,s_height,s_date)
  3.     -> AS SELECT id,name,dept_id,age,sex,height,login_date
  4.     -> FROM tb_students_info;
  5. Query OK, 0 rows affected (0.06 sec)
  6. mysql> SELECT * FROM v_students_info;
  7. +------+--------+------+-------+-------+----------+------------+
  8. | s_id | s_name | d_id | s_age | s_sex | s_height | s_date     |
  9. +------+--------+------+-------+-------+----------+------------+
  10. |    1 | Dany   |    1 |    24 | F     |      160 | 2015-09-10 |
  11. |    2 | Green  |    3 |    23 | F     |      158 | 2016-10-22 |
  12. |    3 | Henry  |    2 |    23 | M     |      185 | 2015-05-31 |
  13. |    4 | Jane   |    1 |    22 | F     |      162 | 2016-12-20 |
  14. |    5 | Jim    |    1 |    24 | M     |      175 | 2016-01-15 |
  15. |    6 | John   |    2 |    21 | M     |      172 | 2015-11-11 |
  16. |    7 | Lily   |    6 |    22 | F     |      165 | 2016-02-26 |
  17. |    8 | Susan  |    4 |    23 | F     |      170 | 2015-10-01 |
  18. |    9 | Thomas |    3 |    22 | M     |      178 | 2016-06-07 |
  19. |   10 | Tom    |    4 |    23 | M     |      165 | 2016-08-05 |
  20. +------+--------+------+-------+-------+----------+------------+
  21. 10 rows in set (0.01 sec)
复制代码
通过这个视图可以很好地掩护根本表中的数据。视图中包罗 s_id、s_name 和 dept_name,s_id 字段对应 tb_students_info 表中的 id 字段,s_name 字段对应 tb_students_info 表中的 name 字段,dept_name 字段对应 tb_departments 表中的 dept_name 字段。
查询视图

视图一经界说之后,就可以如同查询数据表一样,使用 SELECT 语句查询视图中的数据,语法和查询基础表的数据一样。
视图用于查询主要应用在以下几个方面:

DESCRIBE 可以用来查察视图,语法如下:
  1. DESCRIBE 视图名;
复制代码
【实例 4】通过 DESCRIBE 语句查察视图 v_students_info 的界说,输入的 SQL 语句和执行结果如下所示:
  1. mysql> DESCRIBE v_students_info;
  2. +----------+---------------+------+-----+------------+-------+
  3. | Field    | Type          | Null | Key | Default    | Extra |
  4. +----------+---------------+------+-----+------------+-------+
  5. | s_id     | int(11)       | NO   |     | 0          |       |
  6. | s_name   | varchar(45)   | YES  |     | NULL       |       |
  7. | d_id     | int(11)       | YES  |     | NULL       |       |
  8. | s_age    | int(11)       | YES  |     | NULL       |       |
  9. | s_sex    | enum('M','F') | YES  |     | NULL       |       |
  10. | s_height | int(11)       | YES  |     | NULL       |       |
  11. | s_date   | date          | YES  |     | 2016-10-22 |       |
  12. +----------+---------------+------+-----+------------+-------+
  13. 7 rows in set (0.04 sec)
复制代码
  注意:DESCRIBE 一般情况下可以简写成 DESC,输入这个下令的执行结果和输入 DESCRIBE 是一样的。
  黑马步伐员 MySQL数据库入门到精通,从mysql安装到mysql高级、mysql优化全席卷

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4