当前位置: 移动技术网 > IT编程>数据库>Mysql > mysql视图之管理视图实例详解【增删改查操作】

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

2020年03月09日  | 移动技术网IT编程  | 我要评论
本文实例讲述了mysql视图之管理视图操作。分享给大家供大家参考,具体如下: mysql提供了用于显示视图定义的show create view语句,我们来看下语法结构:

本文实例讲述了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/文件夹获取其备份。

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

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网