在本教程中,您将学习如何管理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 | 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
假设您要将职位(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 | 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
删除视图
创建视图后,可以使用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中的视图,包括显示,修改和删除视图。