- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章mysql视图之管理视图实例详解【增删改查操作】由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
本文实例讲述了mysql视图之管理视图操作。分享给大家供大家参考,具体如下:
mysql提供了用于显示视图定义的SHOW CREATE VIEW语句,我们来看下语法结构:
1
|
SHOW
CREATE
VIEW
[database_name].[view_
name
];
|
要显示视图的定义,需要在SHOW CREATE VIEW子句之后指定视图的名称,我们先来根据employees表创建一个简单的视图用来显示公司组织结构,完事在进行演示:
1
2
3
4
5
6
7
8
9
|
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;
|
从以上视图中查询数据,得到以下结果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
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语句如下:
1
|
SHOW
CREATE
VIEW
organization;
|
我们还可以使用任何纯文本编辑器(如记事本)显示视图的定义,以打开数据库文件夹中的视图定义文件。例如,要打开organization视图定义,可以在数据库文件夹下的data文件夹中找到你数据库文件夹,完事进入其中按着你视图名称找.frm文件.
我们再来通过ALTER VIEW和CREATE OR REPLACE VIEW来尝试修改视图,先来看下alert view语法:
1
2
3
4
5
|
ALTER
[ALGORITHM = {MERGE | TEMPTABLE | UNDEFINED}]
VIEW
[database_name]. [view_name]
AS
[
SELECT
statement]
|
以下语句通过添加email列来演示如何修改organization视图:
1
2
3
4
5
6
7
8
9
|
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视图中查询数据,咱就不赘述了,完事来看下另一个语法结构:
1
2
3
4
5
6
7
|
CREATE
OR
REPLACE
VIEW
v_contacts
AS
SELECT
firstName, lastName, extension, email
FROM
employees;
-- 查询视图数据
SELECT
*
FROM
v_contacts;
|
我们要注意,在我们修改的时候,如果一个视图已经存在,mysql只会修改视图。如果视图不存在,mysql将创建一个新的视图。好啦,我们来看下上述sql执行的结果:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
+
-----------+-----------+-----------+--------------------------------+
| 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视图中,只需使用以下语句:
1
2
3
4
5
6
7
|
CREATE
OR
REPLACE
VIEW
v_contacts
AS
SELECT
firstName, lastName, extension, email, jobtitle
FROM
employees;
-- 查询视图数据
SELECT
*
FROM
v_contacts;
|
执行上面查询语句后,可以看到添加一列数据:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
+
-----------+-----------+-----------+--------------------------------+----------------------+
| 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语句将视图删除,先来看下语法结构:
1
|
DROP
VIEW
[IF EXISTS] [database_name].[view_name]
|
上述sql中,IF EXISTS是语句的可选子句,它允许我们检查视图是否存在,用来避免删除不存在的视图的错误。完事我们来删除organization视图:
1
|
DROP
VIEW
IF EXISTS organization;
|
我们得注意下,每次修改或删除视图时,mysql会将视图定义文件备份到/database_name/arc/目录中。 如果我们意外修改或删除视图,可以从/database_name/arc/文件夹获取其备份.
好啦,本次记录就到这里了.
希望本文所述对大家MySQL数据库计有所帮助.
原文链接:https://blog.csdn.net/luyaran/article/details/81019091 。
最后此篇关于mysql视图之管理视图实例详解【增删改查操作】的文章就讲到这里了,如果你想了解更多关于mysql视图之管理视图实例详解【增删改查操作】的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
阅读目录 1、视图介绍 2、创建视图 3、查询视图 4、修改视图 5、删除视图 6、检查选项
基于函数的视图你已经get了,基于类的视图get了吗?CBV本质不知道?点进来看源码分析~ Django 视图之FBV 与 CBV FBV(function base views) 基于函数的视图,就
SQLite 视图(View) 视图(View)只不过是通过相关的名称存储在数据库中的一个 SQLite 语句。视图(View)实际上是一个以预定义的 SQLite 查询形式存在的表的组合。 视图
视图 什么是视图?视图的作用是什么? 视图(view)是一种虚拟存在的表,是一个逻辑表,它本身是不包含数据的。作为一个select语句保存在数据字典中的。 通过视图,可以展现基表(用来创建视图
代码如下: CREATE OR REPLACE VIEW BLOG_V_ADMIN (ID,NICKNAME,SEX,EMAIL,
创建视图 视图包含应用的 HTML 代码,并将应用的控制器逻辑和表现逻辑进行分离。视图文件存放在 resources/views 目录中。下面是一个简单的视图示例:
加密测试的存储过程 ? 1
简介数据库快照 数据库快照,正如其名称所示那样,是数据库在某一时间点的视图。是SQL Server在2005之后的版本引入的特性。快照
一 ,mysql事务 MYSQL中只有INNODB类型的数据表才能支持事务处理。 启动事务有两种方法 (1) 用begin,rollback,commit来实现 复制代码代码如
前言 在日常开发中,存储数据的最常用的方式便是数据库了,其中最为著名的便是MySQL数据库,因它简便易于上手而且可扩展性强大,跨平台使得它广为使用。上一篇文章,我们讲到了它的安装,今天我们就来
1、视图 视图:VIEW,虚表,保存有实表的查询结果,实际数据不保存在磁盘 物化视图:实际数据在磁盘中有保存,加快访问,MySQL不支持物化视图 基表:视图依赖的表 视图中的数据事实上
事项开启和使用 ? 1
代码如下: create PROCEDURE sp_decrypt(@objectName varchar(50)) AS begin begin tran&
前言 在之前 《Oracle打怪升级之路一》中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图、序列、同义词、索引等,以及PL/SQL编
我是一名优秀的程序员,十分优秀!