MySQL学习入门教程:管理视图(显示,修改和删除)

2018-11-3009:20:46数据库教程Comments2,937 views字数 4020阅读模式

学习如何管理MySQL中的视图,包括显示,修改和删除视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

查看视图定义

MySQL提供了用于显示视图定义的SHOW CREATE VIEW语句。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

以下是SHOW CREATE VIEW语句的语法:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

SHOW CREATE VIEW [database_name].[view_ name];
SQL

要显示视图的定义,需要在SHOW CREATE VIEW子句之后指定视图的名称。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

为了更好的演示,我们先来创建一个视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

假设根据employees表创建一个简单的视图用来显示公司组织结构:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

USE yiibaidb;
CREATE VIEW organization AS
    SELECT 
        CONCAT(E.lastname, E.firstname) AS Employee,
        CONCAT(M.lastname, M.firstname) AS Manager
    FROM
        employees AS E
            INNER JOIN
        employees AS M ON M.employeeNumber = E.ReportsTo
    ORDER BY Manager;
SQL

从以上视图中查询数据,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

mysql> SELECT * FROM organization;
+------------------+------------------+
| Employee         | Manager          |
+------------------+------------------+
| BondurLoui       | BondurGerard     |
| CastilloPamela   | BondurGerard     |
| JonesBarry       | BondurGerard     |
| HernandezGerard  | BondurGerard     |
.......此处省略了一大波数据.......
| KatoYoshimi      | NishiMami        |
| KingTom          | PattersonWilliam |
| MarshPeter       | PattersonWilliam |
| FixterAndy       | PattersonWilliam |
+------------------+------------------+
24 rows in set
SQL

要显示视图的定义,请使用SHOW CREATE VIEW语句如下:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

SHOW CREATE VIEW organization;
SQL

还可以使用任何纯文本编辑器(如记事本)显示视图的定义,以打开数据库文件夹中的视图定义文件。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

例如,要打开organization视图定义,可以使用以下路径找到视图定义文件:\data\yiibaidb\organization.frm文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

但是,不应该直接在.frm文件中修改视图的定义。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

修改视图

MySQL提供两个语句,允许您修改现有视图:ALTER VIEWCREATE OR REPLACE VIEW文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

使用ALTER VIEW语句修改视图文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

创建视图后,可以使用ALTER VIEW语句修改视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

ALTER VIEW语句的语法类似于CREATE VIEW语句,除了CREATE关键字被ALTER关键字替换外,其它都一样。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

ALTER
 [ALGORITHM =  {MERGE | TEMPTABLE | UNDEFINED}]
  VIEW [database_name].  [view_name]
   AS 
 [SELECT  statement]
SQL

以下语句通过添加email列来演示如何修改organization视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

ALTER VIEW organization
  AS 
  SELECT CONCAT(E.lastname,E.firstname) AS Employee,
         E.email AS  employeeEmail,
         CONCAT(M.lastname,M.firstname) AS Manager
  FROM employees AS E
  INNER JOIN employees AS M
    ON M.employeeNumber = E.ReportsTo
  ORDER BY Manager;
SQL

要验证更改,可以从organization视图中查询数据:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

SELECT 
    *
FROM
    Organization;
SQL

执行上面查询语句,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html



Shell

使用CREATE OR REPLACE VIEW语句修改视图文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

ALTER VIEW语句外,还可以使用CREATE OR REPLACE VIEW语句来创建或替换现有视图。如果一个视图已经存在,MySQL只会修改视图。如果视图不存在,MySQL将创建一个新的视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

以下语句使用CREATE OR REPLACE VIEW语法根据employees表创建一个名称为v_contacts的视图:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

CREATE OR REPLACE VIEW v_contacts AS
    SELECT 
        firstName, lastName, extension, email
    FROM
        employees;
-- 查询视图数据
SELECT * FROM v_contacts;
SQL

执行上面查询语句,得到以下结果 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

+-----------+-----------+-----------+--------------------------------+
| firstName | lastName  | extension | email                          |
+-----------+-----------+-----------+--------------------------------+
| Diane     | Murphy    | x5800     | dmurphy@yiibai.com             |
| Mary      | Hill      | x4611     | mary.hill@yiibai.com           |
| Jeff      | Firrelli  | x9273     | jfirrelli@yiibai.com           |
| William   | Patterson | x4871     | wpatterson@yiibai.com          |
| Gerard    | Bondur    | x5408     | gbondur@gmail.com              |
| Anthony   | Bow       | x5428     | abow@gmail.com                 |
| Leslie    | Jennings  | x3291     | ljennings@yiibai.com           |
.............. 此处省略了一大波数据 ..................................
| Martin    | Gerard    | x2312     | mgerard@gmail.com              |
| Lily      | Bush      | x9111     | lilybush@yiiibai.com           |
| John      | Minsu     | x9112     | johnminsu@classicmodelcars.com |
+-----------+-----------+-----------+--------------------------------+
25 rows in set
Shell

假设您要将职位(jobtitle)列添加到v_contacts视图中,只需使用以下语句 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

CREATE OR REPLACE VIEW v_contacts AS
    SELECT 
        firstName, lastName, extension, email, jobtitle
    FROM
        employees;
-- 查询视图数据
SELECT * FROM v_contacts;
SQL

执行上面查询语句后,可以看到添加一列数据 -文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

+-----------+-----------+-----------+--------------------------------+----------------------+
| firstName | lastName  | extension | email                          | jobtitle             |
+-----------+-----------+-----------+--------------------------------+----------------------+
| Diane     | Murphy    | x5800     | dmurphy@yiibai.com             | President            |
| Mary      | Hill      | x4611     | mary.hill@yiibai.com           | VP Sales             |
| Jeff      | Firrelli  | x9273     | jfirrelli@yiibai.com           | VP Marketing         |
...................  此处省略了一大波数据 ....................................................
| Yoshimi   | Kato      | x102      | ykato@gmail.com                | Sales Rep            |
| Martin    | Gerard    | x2312     | mgerard@gmail.com              | Sales Rep            |
| Lily      | Bush      | x9111     | lilybush@yiiibai.com           | IT Manager           |
| John      | Minsu     | x9112     | johnminsu@classicmodelcars.com | SVP Marketing        |
+-----------+-----------+-----------+--------------------------------+----------------------+
25 rows in set
SQL

删除视图

创建视图后,可以使用DROP VIEW语句将其删除。下面说明了DROP VIEW语句的语法:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

DROP VIEW [IF EXISTS] [database_name].[view_name]
SQL

IF EXISTS是语句的可选子句,它允许您检查视图是否存在。它可以避免删除不存在的视图的错误。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

例如,如果要删除organization视图,可以按如下所示使用DROP VIEW语句:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

DROP VIEW IF EXISTS organization;
SQL

每次修改或删除视图时,MySQL会将视图定义文件备份到/database_name/arc/目录中。 如果您意外修改或删除视图,可以从/database_name/arc/文件夹获取其备份。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

在本教程中,您已经学会了如何管理MySQL中的视图,包括显示,修改和删除视图。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/sjk/8422.html

  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/sjk/8422.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定