1. 视图简介

1.1 视图定义

  视图是一种虚拟的表,是从数据库中一个或多个表中导出来的表。

  视图可以从已存在的视图的基础上定义。

  数据库中只存放视图的定义,并没有存放视图中的数据,数据存放在原来的表中。

  视图中的数据依赖于原来的表中的数据,表中的数据发生变化,显示在视图中的数据也会改变。

1.2 视图作用

  (1)增加数据安全性

  通过视图,用户只能查询和修改指定的数据。

  数据库授权命令可以限制用户的操作权限,但不能限制到特定行和列上。使用视图可以将用户的权限限制到特定的行和列上。

  (2)提高表的逻辑独立性

  视图可以屏蔽原有表结构变化带来的影响。

  原有的表结构增加列和删除未被引用的列,对视图不造成影响。

2. 创建视图

2.1 创建视图语法

  CREATE VIEW语法形式:

CERATE [ALGORITHM = { UNDEFINED | MERGE | TEMPTABLE }]
VIEW view_name [(column_name, .. ,column_name)]
AS SELECT statement
[WITH [CASCADED | LOCAL] CHECK OPTION];

  其中:

  ALGORITHM:视图选择的算法,包括UNDEFINED,MERGE及TEMPTABLE。

    UNDEFINED:MySQL将自动选择所需要的算法;

    MERGE:将使用视图的语句与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分;

    TEMPTABLE:将视图的结果存入临时表,使用临时表执行语句。

  CASCADED:表示更新视图时,要满足所有相关视图和表的条件,该参数为默认值。

  LOCAL:表示更新视图时,要满足该视图本身的定义的条件即可。

  使用CREATE VIEW语句创建视图时,最好加上WITH CASCADED CHECK OPTION参数。

  创建视图时,需要有CREATE VIEW权限。同时具有查询涉及列的SELECT权限。

  在mysql数据库的user表中保存用户权限,使用SELECT语句查询:

mysql> SELECT Select_priv,Create_view_priv FROM mysql.user WHERE user='root';
+-------------+------------------+
| Select_priv | Create_view_priv |
+-------------+------------------+
| Y | Y |
+-------------+------------------+

2.2 创建视图示例

mysql> CREATE VIEW vproduct
-> AS
-> SELECT ProductID,ProductName FROM product;
mysql> CREATE VIEW vproduct(ProductID,ProductName)
-> AS
-> SELECT ProductID,ProductName FROM product;

3. 查看视图

  查看视图是指查看数据库中已存在的视图的定义,查看视图要有SHOW VIEW权限。

  查看视图的方法包括:DESCRIBE、SHOW TABLE STATUS、SHOW CREATE VIEW及查询information_schema数据库下的views表。

3.1 DESCRIBE语句查看视图基本信息

  语法格式:

DESCRIBE view_name

  示例:

mysql> DESC vproduct;
+-------------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-------------+-------------+------+-----+---------+-------+
| ProductID | int(11) | NO | | NULL | |
| ProductName | varchar(50) | YES | | NULL | |
+-------------+-------------+------+-----+---------+-------+

3.2 SHOW TABLE STATUS语句查看视图基本信息

  语法格式:

SHOW TABLE STATUS LIKE 'view_name'

  示例:

mysql> SHOW TABLE STATUS LIKE 'vproduct';
mysql> show table status like 'vproduct'\G
*************************** 1. row ***************************
Name: vproduct
Engine: NULL
Version: NULL
Row_format: NULL
Rows: NULL
Avg_row_length: NULL
Data_length: NULL
Max_data_length: NULL
Index_length: NULL
Data_free: NULL
Auto_increment: NULL
Create_time: NULL
Update_time: NULL
Check_time: NULL
Collation: NULL
Checksum: NULL
Create_options: NULL
Comment: VIEW
1 row in set (0.00 sec)

  执行结果显示,Comment值为VIEW,说明该表为视图。存储引擎、数据长度等信息都显示为NULL,说明视图是虚拟表。

3.3 SHOW CREATE VIEW语句查看视图详细信息

  语法格式:

SHOW CREATE VIEW view_name

  示例:

mysql> SHOW CREATE VIEW vproduct\G
*************************** 1. row ***************************
View: vproduct
Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `vproduct` AS select `product`.`ProductID` AS `ProductID`,`product`.`ProductName` AS `ProductName` from `product`
character_set_client: gbk
collation_connection: gbk_chinese_ci
1 row in set (0.11 sec)

3.4 在views表中查看视图详细信息

mysql> SELECT * FROM information_schema.views WHERE TABLE_NAME='vproduct'\G
*************************** 1. row ***************************
TABLE_CATALOG: def
TABLE_SCHEMA: portal
TABLE_NAME: vproduct
VIEW_DEFINITION: select `portal`.`product`.`ProductID` AS `ProductID`,`portal`.`product`.`ProductName` AS `ProductName` from `portal`.`product`
CHECK_OPTION: NONE
IS_UPDATABLE: YES
DEFINER: root@localhost
SECURITY_TYPE: DEFINER
CHARACTER_SET_CLIENT: gbk
COLLATION_CONNECTION: gbk_chinese_ci
1 row in set (0.00 sec)

4. 修改视图

  MySQL中通过CREATE OR REPLACE VIEW语句和ALTER语句来修改视图。

4.1 CREATE OR REPLACE VIEW语句修改视图

  CREATE OR REPLACE VIEW语句可以用来修改视图,在视图已存在的情况下,修改视图;视图不存在时,创建视图。

  CREATE OR REPLACE VIEW语法格式:

CERATE OR REPLACE [ALGORITHM = { UNDEFINED | MERGE | TEMPTABLE }]
VIEW view_name [(column_name, .. ,column_name)]
AS SELECT statement
[WITH [CASCADED | LOCAL] CHECK OPTION];

  示例:

mysql> CREATE OR REPLACE VIEW vproduct
-> AS
-> SELECT ProductID,ProductName FROM product;

4.2 ALTER语句修改视图

  ALTER VIEW语法格式:

ALTER [ALGORITHM = { UNDEFINED | MERGE | TEMPTABLE }]
VIEW view_name [(column_name, .. ,column_name)]
AS SELECT statement
[WITH [CASCADED | LOCAL] CHECK OPTION];

  示例:

mysql> ALTER VIEW vproduct
-> AS
-> SELECT ProductID,ProductName FROM product
-> WITH CASCADED CHECK OPTION;

5. 删除视图

  删除视图是指删除数据库中已存在的视图。删除视图时,只能删除视图的定义,不会删除数据。

  语法形式:

DROP VIEW [IF EXISTS] view_name,[view_name] [RESTRICT | CASCADE]

  其中,IF EXISTS判断视图存在,若存在则执行,不存在则不执行。删除多个视图之间使用逗号隔开。

  示例:

mysql> DROP VIEW IF EXISTS vproduct;

MySQL系列:视图基本操作(3)的更多相关文章

  1. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

  2. MySQL 系列(四)主从复制、备份恢复方案生产环境实战

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

  3. MySQL系列(一)--基础知识大总结

    MySQL系列(一)---基础知识大总结 前言:本文主要为mysql基础知识的大总结,mysql的基础知识很多,这里只是作为简单的介绍,但是具体的细节还是需要自行搜索.当然本文还有很多遗漏的地方,后续 ...

  4. MySQL 系列(二)Jdbc

    MySQL 系列(二)Jdbc 一.Jdbc 基本操作 import java.sql.Connection; import java.sql.DriverManager; import java.s ...

  5. MySQL系列(一)--基础知识(转载)

    安装就不说了,网上多得是,我的MySQL是8.0版本,可以参考:CentOS7安装MySQL8.0图文教程和MySQL8.0本地访问设置为远程访问权限 我的MySQL安装在阿里云上面,阿里云向外暴露端 ...

  6. MySQL强人“锁”难《死磕MySQL系列 三》

    系列文章 一.原来一条select语句在MySQL是这样执行的<死磕MySQL系列 一> 二.一生挚友redo log.binlog<死磕MySQL系列 二> 前言 最近数据库 ...

  7. MySQL统计总数就用count(*),别花里胡哨的《死磕MySQL系列 十》

    有一个问题是这样的统计数据总数用count(*).count(主键ID).count(字段).count(1)那个效率高. 先说结论,不用那么花里胡哨遇到统计总数全部使用count(*). 但是有很多 ...

  8. MySQL 系列(二) 你不知道的数据库操作

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 本章内容: 查看\创建\使用\删除 数据库 用户管理及授权实战 局域网 ...

  9. mysql数据库视图连接出现2003····错误

    MySQL利用视图工具连接数据库时出现2003····错误                                                  原因:MySQL的服务没有开启 解决步骤: ...

  10. mysql 查询表,视图,触发器,函数,存储过程

    1. mysql查询所有表: SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名' AND  TAB ...

随机推荐

  1. [CQOI2018]破解D-H协议

    嘟嘟嘟 这不就是个bsgs板儿嘛. 顺便就复习了一下bsgs和哈希表. 头一次觉得我的博客这么好用,一下就懂了:数论学习笔记之高次不定方程 这里再补充几点: 1.关于这一段代码: int S = sq ...

  2. ssm框架的整合搭建(一)

    一个转行菜鸟半年多工作的开始学习历程............ 我是自学,也是我的记录,我学习的见证,如果你有幸看见,不要吐槽,不足之处请指点,相互学习,谢谢!! 请一起共勉!!!!!!!! 使用技术: ...

  3. scipy 安装错误及解决

    pip 安装 scipy 时,因为是编译安装,所以如果缺少一些编译库,会报很多错误,以下总结可能缺失的安装包: sudo apt-get install gfortran sudo apt-get i ...

  4. Intellij Idea 2017创建web项目及tomcat部署实战

    相关软件:Intellij Idea2017.jdk16.tomcat7 Intellij Idea直接安装(可根据需要选择自己设置的安装目录),jdk使用1.6/1.7/1.8都可以,主要是配置好系 ...

  5. Spring-boot 编写hello world

    项目启动时出现如下报错信息: Unrecognized VM option 'TieredStopAtLevel=1' Could not create the Java virtual machin ...

  6. CentOS 6.5下RPM方式(重新)安装MySQL 5.7.21从头到尾篇

    强烈推荐参阅这一篇教程  https://www.cnblogs.com/kevingrace/p/8340690.html 下面我写的仅供参考 今天把Mysql5.1升级到了5.7,浪费了一天为了避 ...

  7. web安全:通俗易懂,以实例讲述破解网站的原理及如何进行防护!如何让网站变得更安全。

    本篇以我自己的网站为例来通俗易懂的讲述网站的常见漏洞,如何防止网站被入侵,如何让网站更安全. 要想足够安全,首先得知道其中的道理. 本文例子通俗易懂,主要讲述了 各种漏洞 的原理及防护,相比网上其它的 ...

  8. ASP.Net Core2.1中的HttpClientFactory系列一:HttpClient的缺陷

    引言: ASP.NET Core2.1 中出现了一个新的 HttpClientFactory 功能, 它有助于解决开发人员在使用 HttpClient 实例从其应用程序中访问外部 web 资源时可能遇 ...

  9. CentOS 7+nginx+PHP+php-fpm

    根据网上资料配置: location ~ \.php$ { #include fastcgi_params; fastcgi_pass 127.0.0.1:9000; fastcgi_index in ...

  10. CodeForces 550E Brackets in Implications 推理

    给出一个四个规则 0->0=1  0->1=1 1->0=0  1->1=0 我自己当时一味的去找规律,没有把式子好好推一推. 当然每个人都能想到a[n]=0是必须的 当a[n ...