MySQL管理视图 您所在的位置:网站首页 MySQL查看视图结构 MySQL管理视图

MySQL管理视图

2023-03-11 04:00| 来源: 网络整理| 查看: 265

在本教程中,您将学习如何管理MySQL中的视图,包括显示,修改和删除视图。

查看视图定义

MySQL提供了用于显示视图定义的SHOW CREATE VIEW语句。

以下是SHOW CREATE VIEW语句的语法:

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

要显示视图的定义,需要在SHOW CREATE VIEW子句之后指定视图的名称。

为了更好的演示,我们先来创建一个视图。

假设根据employees表创建一个简单的视图用来显示公司组织结构:

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;

从以上视图中查询数据,得到以下结果 -

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

要显示视图的定义,请使用SHOW CREATE VIEW语句如下:

SHOW CREATE VIEW organization;

还可以使用任何纯文本编辑器(如记事本)显示视图的定义,以打开数据库文件夹中的视图定义文件。

例如,要打开organization视图定义,可以使用以下路径找到视图定义文件:\data\yiibaidb\organization.frm。

但是,不应该直接在.frm文件中修改视图的定义。

修改视图

MySQL提供两个语句,允许您修改现有视图:ALTER VIEW和CREATE OR REPLACE VIEW 。

使用ALTER VIEW语句修改视图

创建视图后,可以使用ALTER VIEW语句修改视图。

ALTER VIEW语句的语法类似于CREATE VIEW语句,除了CREATE关键字被ALTER关键字替换外,其它都一样。

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

以下语句通过添加email列来演示如何修改organization视图。

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;

要验证更改,可以从organization视图中查询数据:

SELECT * FROM Organization;

执行上面查询语句,得到以下结果 -

使用CREATE OR REPLACE VIEW语句修改视图

除ALTER VIEW语句外,还可以使用CREATE OR REPLACE VIEW语句来创建或替换现有视图。如果一个视图已经存在,MySQL只会修改视图。如果视图不存在,MySQL将创建一个新的视图。

以下语句使用CREATE OR REPLACE VIEW语法根据employees表创建一个名称为v_contacts的视图:

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

执行上面查询语句,得到以下结果 -

+-----------+-----------+-----------+--------------------------------+ | firstName | lastName | extension | email | +-----------+-----------+-----------+--------------------------------+ | Diane | Murphy | x5800 | [email protected] | | Mary | Hill | x4611 | [email protected] | | Jeff | Firrelli | x9273 | [email protected] | | William | Patterson | x4871 | [email protected] | | Gerard | Bondur | x5408 | [email protected] | | Anthony | Bow | x5428 | [email protected] | | Leslie | Jennings | x3291 | [email protected] | .............. 此处省略了一大波数据 .................................. | Martin | Gerard | x2312 | [email protected] | | Lily | Bush | x9111 | [email protected] | | John | Minsu | x9112 | [email protected] | +-----------+-----------+-----------+--------------------------------+ 25 rows in set

假设您要将职位(jobtitle)列添加到v_contacts视图中,只需使用以下语句 -

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

执行上面查询语句后,可以看到添加一列数据 -

+-----------+-----------+-----------+--------------------------------+----------------------+ | firstName | lastName | extension | email | jobtitle | +-----------+-----------+-----------+--------------------------------+----------------------+ | Diane | Murphy | x5800 | [email protected] | President | | Mary | Hill | x4611 | [email protected] | VP Sales | | Jeff | Firrelli | x9273 | [email protected] | VP Marketing | ................... 此处省略了一大波数据 .................................................... | Yoshimi | Kato | x102 | [email protected] | Sales Rep | | Martin | Gerard | x2312 | [email protected] | Sales Rep | | Lily | Bush | x9111 | [email protected] | IT Manager | | John | Minsu | x9112 | [email protected] | SVP Marketing | +-----------+-----------+-----------+--------------------------------+----------------------+ 25 rows in set 删除视图

创建视图后,可以使用DROP VIEW语句将其删除。下面说明了DROP VIEW语句的语法:

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

IF EXISTS是语句的可选子句,它允许您检查视图是否存在。它可以避免删除不存在的视图的错误。

例如,如果要删除organization视图,可以按如下所示使用DROP VIEW语句:

DROP VIEW IF EXISTS organization;

每次修改或删除视图时,MySQL会将视图定义文件备份到/database_name/arc/目录中。 如果您意外修改或删除视图,可以从/database_name/arc/文件夹获取其备份。

在本教程中,您已经学会了如何管理MySQL中的视图,包括显示,修改和删除视图。

上一篇: MySQL视图 下一篇: MySQL触发器


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有