mysql视图之管理视图实例详解【增删改查操作】

 更新时间:2019年12月16日 09:48:45   作者:luyaran  
这篇文章主要介绍了mysql视图之管理视图,结合实例形式详细分析了mysql视图增删改查操作具体实现技巧与相关操作注意事项,需要的朋友可以参考下

本文实例讲述了mysql视图之管理视图操作。分享给大家供大家参考,具体如下:

mysql提供了用于显示视图定义的SHOW CREATE VIEW语句,我们来看下语法结构:

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

要显示视图的定义,需要在SHOW CREATE VIEW子句之后指定视图的名称,我们先来根据employees表创建一个简单的视图用来显示公司组织结构,完事在进行演示:

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   |
.......此处省略了many many数据.......
| KatoYoshimi   | NishiMami    |
| KingTom     | PattersonWilliam |
| MarshPeter    | PattersonWilliam |
| FixterAndy    | PattersonWilliam |
+------------------+------------------+
24 rows in set

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

SHOW CREATE VIEW organization;

我们还可以使用任何纯文本编辑器(如记事本)显示视图的定义,以打开数据库文件夹中的视图定义文件。例如,要打开organization视图定义,可以在数据库文件夹下的data文件夹中找到你数据库文件夹,完事进入其中按着你视图名称找.frm文件。

我们再来通过ALTER VIEW和CREATE OR REPLACE VIEW来尝试修改视图,先来看下alert view语法:

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视图中查询数据,咱就不赘述了,完事来看下另一个语法结构:

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

我们要注意,在我们修改的时候,如果一个视图已经存在,mysql只会修改视图。如果视图不存在,mysql将创建一个新的视图。好啦,我们来看下上述sql执行的结果:

+-----------+-----------+-----------+--------------------------------+
| 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      |
.............. 此处省略了many many数据 ..................................
| 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 [IF EXISTS] [database_name].[view_name]

上述sql中,IF EXISTS是语句的可选子句,它允许我们检查视图是否存在,用来避免删除不存在的视图的错误。完事我们来删除organization视图:

DROP VIEW IF EXISTS organization;

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

好啦,本次记录就到这里了。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL查询技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》、《MySQL数据库锁相关技巧汇总》及《MySQL常用函数大汇总

希望本文所述对大家MySQL数据库计有所帮助。

相关文章

  • MySQL Workbench导入excel数据的实现示例

    MySQL Workbench导入excel数据的实现示例

    本文主要介绍了MySQL Workbench导入excel数据的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • 深入mysql并发插入优化详解

    深入mysql并发插入优化详解

    本篇文章是对mysql并发插入优化进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • mysql查看索引的方式

    mysql查看索引的方式

    这篇文章主要介绍了mysql查看索引的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • MySQL数据库操作常用命令小结

    MySQL数据库操作常用命令小结

    这篇文章主要介绍了MySQL数据库操作常用命令小结,例如创建数据库、使用数据库、查看数据库、数据库编码操作等命令讲解,需要的朋友可以参考下
    2014-12-12
  • MySQL分库分表的几种方式

    MySQL分库分表的几种方式

    这篇文章主要介绍了MySQL分库分表的几种方式,分库分表方案是对关系型数据库数据存储和访问机制的一种补充,下文更多相关介绍需要的小伙伴可以参考一下
    2022-04-04
  • MySQL和MySQL驱动mysql-connector-java升级到8.0.X版本问题

    MySQL和MySQL驱动mysql-connector-java升级到8.0.X版本问题

    这篇文章主要介绍了MySQL和MySQL驱动mysql-connector-java升级到8.0.X版本问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • Windows系统下MySQL8.0.21安装教程(图文详解)

    Windows系统下MySQL8.0.21安装教程(图文详解)

    这篇文章主要介绍了Windows系统下MySQL8.0.21安装教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • MySQL中Select查询语句的高级用法分享

    MySQL中Select查询语句的高级用法分享

    MySQL是一个开源的关系型数据库管理系统,支持多种操作语言,其中最基础、最常用的命令之一就是SELECT语句,所以本文就来和大家聊聊Select查询语句的几个高级用法吧
    2023-05-05
  • MySQL 8.0 对 limit 的优化技巧

    MySQL 8.0 对 limit 的优化技巧

    从不同版本的 MySQL 发展轨迹来看 MySQL 的优化器越来越智能 (比如大家期待已久的直方图特性) ,能更多的减少人为干预,提升执行计划的准确性,这篇文章主要介绍了MySQL 8.0 对 limit 的优化,需要的朋友可以参考下
    2022-10-10
  • linux下改良版本mysqldump来备份MYSQL数据库

    linux下改良版本mysqldump来备份MYSQL数据库

    我的备份脚本都是在凌晨执行的,经常在慢查询日志里面看到这样的信息:select * from table1; 之前一直很纳闷,最后才了解到原来是MYSQLDUMP搞的鬼。
    2008-07-07

最新评论