Mysql 视图笔记
1. 视图的定义
视图就是从一个或多个表中,导出来的表,是一个虚拟存在的表。视图就像一个窗口(数据展示的窗口),通过这个窗口,可以看到系统专门提供的数据(也可以查看到数据表的全部数据),使用视图就可以不用看到数据表中的所有数据,而是只想得到所需的数据。
在数据库中,只存放了视图的定义,并没有存放视图的数据,数据还是存储在原来的表里,视图的数据是依赖原来表中的数据的,所以原来的表的数据发生了 改变,那么显示的视图的数据也会跟着改变,例如向数据表中插入数据,那么在查看视图的时候,会发现视图中也被插入了同样的数据。
视图在外观上和表很相似,但是它不需要实际上的物理存储,视图实际上是由预定义的查询形式的表所组成的。
视图可以包含表的全部或者部分记录,也可以由一个表或者多个表来创建,当我们创建一个视图的时候,实际上是在数据库里执行了SELECT语句,SELECT语句包含了字段名称、函数、运算符,来给用户显示数据。
在数据库中,视图的使用方式与表的使用方式一致,我们可以像操作表一样去操作视图,或者去获取数据。
一般来说,我们只是利用视图来查询数据,不会通过视图来操作数据。
1.1 基于视图的视图
基于已存在的视图,还可以再创建视图。
1.2 视图和表的区别
视图和表的主要区别,就是看是否占用物理空间。
1.3 视图的作用
(1)选取有用的信息,筛选的作用
(2)操作简单化,所见即所需,视图看到的信息,就是需要了解的信息
(3)增加数据的安全性:查询或者修改指定的数据,非指定的数据是触碰不到的。
(4)提高逻辑的独立性
1.4 视图的特点
(1)简单性(简单化):可以展现特定的数据,而无需重复设置查询条件,简化操作。
(2)安全性:视图可以只展现数据表的一部分数据,对于我们不希望让用户看到全部数据,只希望用户看到部分数据的时候,可以选择使用视图。
(3)逻辑独立性:当真实的数据表结构发生了变化,可以通过视图来屏蔽真实表的结构变化,从而实现了视图的逻辑独立性。
视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。视图可以在以下几个方面使程序与数据独立:
①如果应用建立在数据库表上,当数据库表发生变化时,可以在表上建立视图,通过视图屏蔽表的变化,从而应用程序可以不动。
②如果应用建立在数据库表上,当应用发生变化时,可以在表上建立视图,通过视图屏蔽应用的变化,从而使数据库表不动。
③如果应用建立在视图上,当数据库表发生变化时,可以在表上修改视图,通过视图屏蔽表的变化,从而应用程序可以不动。
④如果应用建立在视图上,当应用发生变化时,可以在表上修改视图,通过视图屏蔽应用的变化,从而数据库可以不动。
2. 创建视图
CREATE VIEW 视图名称[(column_list)] AS SELECT 语句
例:
CREATE VIEW province_view AS SELECT * FROM province;
SELECT * FROM province_view;
说明:创建的视图表province_view与province表一模一样。
2.1 指定视图显示的字段:
CREATE VIEW province_view1(id,name) AS SELECT id,pro_name FROM province;
mysql> SELECT * FROM province_view1;
+-----+------+
| id | name |
+-----+------+
| 1 | 北京 |
| 2 | 上海 |
| 3 | 辽宁 |
| 4 | 天津 |
| 5 | 广东 |
| 6 | 福建 |
| 100 | 吉林 |
+-----+------+
7 rows in set (0.00 sec)
2.2 创建基于两个表的视图:
使用WHERE连接两个表:
CREATE VIEW v3(name,score) AS SELECT s_name,score FROM student,score
WHERE student.s_id=score.s_id
and score.c_id='BY';
2.3 视图的算法
ALGORITHM=
UNDEFINED:MYSQL自动选择要使用的算法
MERGE:使用视图的语句与视图的定义是合并在一起的,视图定义的某一部分取代语句对应的部分
TEMPTABLE:临时表,视图的结果存入临时表,然后使用临时表来执行语句
WHIT [CASCADED|LOCAL] CHECK OPTION:表示更新视图的时候,要保证在视图的权限范围之内:
CASCADED 默认值,表示更新视图的时候,要满足视图和表的相关条件
LOCAL:表示更新视图的时候,要满足该视图定义的一个条件即可
说明:使用WHIT [CASCADED|LOCAL] CHECK OPTION选项可以保证数据的安全性
3.创建完整的视图
CREATE ALGORITHM VIEW 视图名称[(column_list)] AS SELECT 语句
WITH [CASCADED|LOCAL] CHECK OPTION
语法提示命令:? CREATE VIEW
Name: 'CREATE VIEW'
Description:
Syntax:
CREATE
[OR REPLACE]
[ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
[DEFINER = { user | CURRENT_USER }]
[SQL SECURITY { DEFINER | INVOKER }]
VIEW view_name [(column_list)]
AS select_statement
[WITH [CASCADED | LOCAL] CHECK OPTION]
例子:
CREATE ALGORITHM=UNDEFINED VIEW user_view3(id,username,age) AS SELECT
id,username,age FROM users2 WITH CASCADED CHECK OPTION;
4. 查看视图
查看已创建好的视图:
4.1 查看已创建好的视图的方法:
DESC
DESCRIBE
SHOW COLUMNS FROM 视图名称
SHOW TABLE STATUS LIKE
SHOW CREATE VIEW
4.1.1 DESC
mysql> desc user_view3;
+----------+----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+----------------------+------+-----+---------+-------+
| id | smallint(5) unsigned | NO | | 0 | |
| username | varchar(20) | NO | | NULL | |
| age | tinyint(3) unsigned | YES | | NULL | |
+----------+----------------------+------+-----+---------+-------+
3 rows in set (0.02 sec)
4.1.2 DESCRIBE
mysql> DESCRIBE user_view3;
+----------+----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+----------------------+------+-----+---------+-------+
| id | smallint(5) unsigned | NO | | 0 | |
| username | varchar(20) | NO | | NULL | |
| age | tinyint(3) unsigned | YES | | NULL | |
+----------+----------------------+------+-----+---------+-------+
3 rows in set (0.01 sec)
4.1.3 SHOW COLUMNS FROM 视图名称
mysql> SHOW COLUMNS FROM user_view3;
+----------+----------------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+----------------------+------+-----+---------+-------+
| id | smallint(5) unsigned | NO | | 0 | |
| username | varchar(20) | NO | | NULL | |
| age | tinyint(3) unsigned | YES | | NULL | |
+----------+----------------------+------+-----+---------+-------+
3 rows in set (0.02 sec)
4.2 查看视图的基本信息(也可查看原表的信息):
SHOW TABLE STATUS LIKE ‘视图名称’;
mysql> SHOW TABLE STATUS LIKE 'province_view'\G;
*************************** 1. row ***************************
Name: province_view
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)
说明:
(1) 可以从Comment: VIEW看出它是一个视图,如果是数据表,Comment选项的值为空。
(2) 因为视图是虚拟出的一张表,所以很多选项的值都是NULL,如果SHOW TABLE STATUS LIKE ‘table_name’; 那么这些选项将会显示出数值。
4.3 查看指定视图的创建信息(专门查看视图信息的命令)
SHOW CREATE VIEW 视图名称;
mysql> SHOW CREATE VIEW user_view3\G;
*************************** 1. row ***************************
View: user_view3
Create View: CREATE ALGORITHM=UNDEFINED DEFINER=`root`@`localhost` SQL SECURITY DEFINER VIEW `user_view3` AS select `users2`.`id` AS `id`,`users2`.`username` AS `username`,`users2`.`age` AS `age` from `users2` WITH CASCADED CHECK OPTION
character_set_client: gbk
collation_connection: gbk_chinese_ci
1 row in set (0.00 sec)
4.4 视图数据的存储位置
mysql> SELECT * FROM information_schema.views\G
所有的视图都保存在了information_schema.views中。
4.5.修改视图:
如果视图不存在,则创建视图,如果视图存在,则修改视图:
(1)CREATE OR REPLACE VIEW 视图名称[(column_list)] AS SELECT 语句
(2)ALTER VIEW视图名称[(column_list)] AS SELECT 语句
4.5.1 CREATE OR REPLACE VIEW 视图名称[(column_list)] AS SELECT 语句
(1)例子:
CREATE OR REPLACE VIEW user_view3(id,username) AS SELECT id,username FROM users2;
(2)如果输入的视图名称不存在,这MYSQL自动创建该视图:
(3)修改视图:
CREATE OR REPLACE ALOGRITHM=TEMPTABLE VIEW user_view4(id) AS SELECT id FROM
users2;
(4)修改基于两个表的视图,两个表使用WHERE进行连接:
CREATE OR REPLACE VIEW v3 AS SELECT s_name,s_sex,score FROM student,score
WHERE student.s_id=score.s_id AND score.c_id='BY';
4.5.2 ALTER
ALTER VIEW 视图名称[(column_list)] AS SELECT 语句
ALTER VIEW user_view4(id,username,age) AS SELECT id,username,age FROM users2;
修改基于两个表的视图:
ALTER VIEW v3 AS SELECT s_name,score FROM student,score
WHERE student.s_id=score.s_id
AND score.c_id='TC';
5.更新视图
所谓更新视图,其实就是通过视图,对数据进行插入,修改和删除的操作。
5.1 修改视图的数据
注意:修改视图的数据,将直接修改数据表(即原表)的真实数据。
UPDATE v3 SET score=100 WHERE s_name='倪妮';
5.2 通过视图插入、删除数据的原理与5.1一致,均与数据表的操作语法一致
6.删除视图:
删除视图,不会影响原表的数据,但是删除视图的数据,则会影响到原表。
6.1 DROP VIEW 视图名称;
DROP VIEW 视图名称;
DROP VIEW user_view4;
6.2 DROP VIEW IF EXISTS
在删除已不存在的视图的时候,不进行任何操作:
DROP VIEW IF EXISTS视图名称;
例:
DROP VIEW IF EXISTS v1;
6.3 删除多个视图
DROP VIEW IF EXISTS v2,v3;
Mysql 视图笔记的更多相关文章
- MySql视图笔记(转载)
1. 视图的定义 视图就是从一个或多个表中,导出来的表,是一个虚拟存在的表.视图就像一个窗口(数据展示的窗口),通过这个窗口,可以看到系统专门提供的数据(也可以查看到数据表的全部数据),使 ...
- Mysql 视图笔记2
这学期开了数据库的课,对sql注入颇感兴趣.因此,对数据库语句也颇为喜爱.遇到了with check option 问题.这属于sql view里面的一个问题.在此略做小结.大牛勿喷! 先自定义一个t ...
- MYSQL视图的学习笔记
MYSQL视图的学习笔记,学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆 课程笔记的综合. 视图及图形化工具 1. 视图的定义 视图就是从一个或多个表中,导出来的表,是一个虚 ...
- Mysql学习笔记—视图
1.什么是视图 视图(View)是一种虚拟存在的表.其内容与真实的表相似,包含一系列带有名称的列和行数据.但是视图并不在数据库中以存储的数据的形式存在.行和列的数据来自定义视图时查询所引用的基本表,并 ...
- MYSQL进阶学习笔记六:MySQL视图的创建,理解及管理!(视频序号:进阶_14,15)
知识点七:MySQL视图的创建(14) 视图的定义: 什么是视图: 视图数由查询结果形成的一张虚拟的表. 什么时候要用到视图? 如果某个查询结果出现的非常频繁,也就是,要经常拿这个查询结果来做子查询. ...
- MySQL学习笔记一
MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...
- MySQL入门笔记
MySQL入门笔记 版本选择: 5.x.20 以上版本比较稳定 一.MySQL的三种安装方式: 安装MySQL的方式常见的有三种: · rpm包形式 · 通用二进制 ...
- MySQL视图更新
昨天在写美团2019秋招笔试题的时候遇到了关于视图是否能更新的问题,突然感觉这个问题之前复习的时候重点关注过,但是却又想不全.今天特地搜了一些资料总结一下.本文主要说明视图的更新限制,如需关于视图的更 ...
- MySQL学习笔记-数据库文件
数据库文件 MySQL主要文件类型有如下几种 参数文件:my.cnf--MySQL实例启动的时候在哪里可以找到数据库文件,并且指定某些初始化参数,这些参数定义了某种内存结构的大小等设置,还介绍了参数类 ...
随机推荐
- java线程同步问题
Java面试当中,线程可以说是必考内容,在看面试题的时候发现一遍很全的讲解Java面试题的博客:http://blog.csdn.net/csh624366188/article/details/80 ...
- 转:ElasticSearch的安装和相关插件的安装
原文来自于:http://blog.csdn.net/whxaing2011/article/details/18237733 本文主要介绍如下内容: 1.ElasticSearch ...
- 破解简单Mifare射频卡密钥杂记
先要了解一点大学城浴卡用的是什么卡,经查证是Mifare S50卡,也有叫ISO14443A的(协议名).本来想看看大学城浴卡有没有安全漏洞,没想到浴卡公司在安全性上几乎是蔑视我们大学生的智商,虽然被 ...
- 线程通信机制:共享内存 VS 消息传递
在并发编程中,我们必须考虑的问题时如何在两个线程间进行通讯.这里的通讯指的是不同的线程之间如何交换信息. 目前有两种方式: 1.共享内存 2.消息传递(actor 模型) 共享内存: 共享内存这种方式 ...
- UVa 10837 A Research Problem 欧拉函数
题意: 给你一个欧拉函数值 phi(n),问最小的n是多少. phi(n) <= 100000000 , n <= 200000000 解题思路: 对于欧拉函数值可以写成 这里的k有可能是 ...
- UNDO 100%
另外查了下v$undostat,发现begin_time已经很久没有改变, BEGIN_TIME END_TIME MAXQUERYLEN MAXCONCU ...
- 【翻译】Organizing ASP.NET MVC solutions 如何组织你的ASP.NET MVC解决方案
序言 时隔一年,弦哥重出江湖,对于我们学习.NET MVC那将有大大的好处,期待弦哥的重构系列.在弦哥与jerrychou的交流中提到了一篇文章http://lostechies.com/jimmyb ...
- Java学习日记8-包、环境变量和访问控制
Java中的包.环境变量和访问控制 一.java中的包 Java利用包来组织代码,一来使大型项目的代码结构清晰,二来包是一个命名空间的划分,即不同包中可以有相同名字的类,只需在在类名前加上包名即可区分 ...
- [Linux] 流 ( Stream )、管道 ( Pipeline ) 、Filter - 笔记
流 ( Stream ) 1. 流,是指可使用的数据元素一个序列. 2. 流,可以想象为是传送带上等待加工处理的物品,也可以想象为工厂流水线上的物品. 3. 流,可以是无限的数据. 4. 有一种功能, ...
- Jenkins的错误“error fetching remote repo origin”的问题解决
错误如上,解决方法收集,可以尝试以下方法: http://stackoverflow.com/questions/38391601/jenkins-error-error-fetching-remot ...