《数据库优化》- MySQL视图
一、什么是视图
视图,是基于一个表或多个表或视图的逻辑表,本身不包含数据,通过它可以对表里面的数据进行查询和修改,视图基于的表称为基表。视图是存储在数据字典里的一条 Select 语句。
通俗地讲,视图就是一条 Select 语句执行后返回的结果集。所以我们在创建视图的时候,主要的工作就落在创建这条 SQL 查询语句上。
二、视图的特性及优点
1、特性:
视图是对若干张基本表的引用,一张虚表,查询语句执行的结果,不存储具体的数据(基本表数据发生了改变,视图也会跟着改变)。
可以跟基本表一样,进行增删改查操作(ps:增删改操作有条件限制);
2、优点:
● 对数据库的访问,因为视图可以有选择性的选取数据库里的一部分。
● 用户通过简单的查询可以从复杂查询中得到结果。
● 维护数据的独立性,视图可从多个表检索数据。
● 对于相同的数据可产生不同的视图。
三、视图的分类、作用及使用场合
1、分类:
视图分为简单视图和复杂视图:
简单视图只从单表里获取数据,复杂视图从多表;
简单视图不包含函数和数据组,复杂视图包含;
简单视图可以实现DML操作,复杂视图不可以。
2、作用:
方便操作,特别是查询操作,减少复杂的SQL语句,增强可读性;
更加安全,数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别;(例如我们只想给其他人展示账号和用户名,密码不展示,则可以通过视图实现。)
3、使用场合:
● 权限控制的时候,不希望用户访问表中某些敏感信息列,例如“salary(薪资)”......
● 关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作;
四、创建视图
有如下3张表:Student(学生)、Course(课程)、学生课程中间表(Student_Course),表结构及数据如下:
- -- ============================
- -- Table structure for `Student`
- -- ----------------------------
- DROP TABLE IF EXISTS `Student`;
- CREATE TABLE `Student` (
- `id` bigint(20) NOT NULL AUTO_INCREMENT,
- `account` varchar(255) NOT NULL,
- `name` varchar(255) NOT NULL,
- `address` varchar(255) DEFAULT NULL,
- `others` varchar(200) DEFAULT NULL,
- `others2` varchar(200) DEFAULT NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
- -- ----------------------------
- -- Records of Student
- -- ----------------------------
- INSERT INTO `Student` VALUES ('', 'Student1', '小陈', '美国', '', '');
- INSERT INTO `Student` VALUES ('', 'Student2', '小张', '日本', '', '');
- INSERT INTO `Student` VALUES ('', 'Student3', '小王', '中国', '', '');
- -- ============================
- -- Table structure for `Course`
- -- ----------------------------
- DROP TABLE IF EXISTS `Course`;
- CREATE TABLE `Course` (
- `id` bigint(20) NOT NULL AUTO_INCREMENT,
- `name` varchar(200) NOT NULL,
- `description` varchar(500) NOT NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
- -- ----------------------------
- -- Records of Course
- -- ----------------------------
- INSERT INTO `Course` VALUES ('', 'JAVA', 'JAVA课程');
- INSERT INTO `Course` VALUES ('', 'C++', 'C++课程');
- INSERT INTO `Course` VALUES ('', 'C语言', 'C语言课程');
- -- ============================
- -- Table structure for `Student_Course`
- -- ----------------------------
- DROP TABLE IF EXISTS `Student_Course`;
- CREATE TABLE `Student_Course` (
- `id` bigint(20) NOT NULL AUTO_INCREMENT,
- `Studentid` bigint(20) NOT NULL,
- `Courseid` bigint(20) NOT NULL,
- PRIMARY KEY (`id`)
- ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
- -- ----------------------------
- -- Records of Student_Course
- -- ----------------------------
- INSERT INTO `Student_Course` VALUES ('', '', '');
- INSERT INTO `Student_Course` VALUES ('', '', '');
- INSERT INTO `Student_Course` VALUES ('', '', '');
- INSERT INTO `Student_Course` VALUES ('', '', '');
- INSERT INTO `Student_Course` VALUES ('', '', '');
- INSERT INTO `Student_Course` VALUES ('', '', '');
表数据:
这时,当我们想要查询小张上的所以课程相关信息的时候,需要这样写一条长长的SQL语句,如下:
- SELECT sc.id AS id, s.name AS Studentname, c.name AS Coursename
- FROM Student s
- LEFT JOIN Student_Course sc
- ON ((s.id = sc.Studentid))
- LEFT JOIN Course c
- ON ((sc.Courseid = c.id))
- WHERE s.name = '小张';
但是,我们可以通过视图简化操作,例如我们创建视图 View_Student_Course,如下:
- -- ============================
- -- View structure for `View_Student_Course`
- -- ----------------------------
- DROP VIEW
- IF EXISTS `View_Student_Course`;
- CREATE ALGORITHM = UNDEFINED
- DEFINER = `root`@`localhost`
- SQL SECURITY DEFINER
- VIEW `View_Student_Course` AS (
- SELECT
- sc.id AS id, s.name AS Studentname, c.name AS Coursename
- FROM
- (
- (
- Student s
- LEFT JOIN Student_Course sc ON ((s.id = sc.Studentid))
- )
- LEFT JOIN Course c ON ((sc.Courseid = c.id))
- )
- );
几点说明(MySQL中的视图在标准SQL的基础之上做了扩展):
● ALGORITHM=UNDEFINED:指定视图的处理算法;
● DEFINER=`root`@`localhost`:指定视图创建者;
● SQL SECURITY DEFINER:指定视图查询数据时的安全验证方式;
创建好视图之后,我们可以直接用以下SQL语句在视图上查询小张上的所以课程相关信息,同样可以得到所需结果:
- SELECT
- vsc.studentname,
- vsc.coursename
- FROM
- View_Student_Course vsc
- WHERE
- vsc.studentname = '小张';
三、视图的增删改
继续,我们可以尝试在视图view_user_course上做增删改数据操作,如下:
- update view_student_course set studentname='test',coursename='JAVASCRIPT' where id=3;
不错所料,操作失败,信息如下:
[SQL] update view_student_course set studentname='test',coursename='JAVASCRIPT' where id=3
[Err] 1393 - Can not modify more than one base table through a join view 'demo.view_student_course'
因为不能在一张由多张关联表连接而成的视图上做同时修改两张表的操作;
那么哪些操作可以在视图上进行呢?
视图与表是一对一关系情况:如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行增删改数据操作;
如我们创建用户关键信息视图 view_student_keyinfo,如下:
- -- ----------------------------
- -- View structure for `view_student_keyinfo`
- -- ----------------------------
- DROP VIEW
- IF EXISTS `view_student_keyinfo`;
- CREATE ALGORITHM = UNDEFINED DEFINER = `root`@`localhost` SQL SECURITY DEFINER VIEW `view_student_keyinfo` AS SELECT
- `u`.`id` AS `id`,
- `u`.`account` AS `account`,
- `u`.`name` AS `studentname`
- FROM
- `student` `u`;
进行增删改操作如下,操作成功(注意 student 表中的其它字段要允许为空,否则操作失败):
- INSERT INTO view_student_keyinfo (account, studentname)
- VALUES
- ('test1', 'test1');
- DELETE
- FROM
- view_student_keyinfo
- WHERE
- studentname = 'test1';
- UPDATE view_student_keyinfo
- SET studentname = 'updatestudent'
- WHERE
- id = 1
视图与表是一对多关系情况:如果只修改一张表的数据,且没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行修改数据操作,如以下语句,操作成功;
- update view_student_course set coursename='JAVA' where id=1;
- update view_student_course set studentname='test2' where id=3;
以下操作失败:
- delete from view_student_course where id=3;
- insert into view_student_course(studentname, coursename) VALUES('','');
四、其他
视图中的查询语句性能要调到最优;
修改操作时要小心,不经意间你已经修改了基本表里的多条数据;
其它性能相关方面待实践体会...
转载自:风一样的码农 - 《Mysql中的视图》
《数据库优化》- MySQL视图的更多相关文章
- Mysql 视图 游标 触发器 存储过程 事务
Mysql 视图 触发器 存储过程 游标 游标是从数据表中提取出来的数据,以临时表的形式存放在内存中,在游标中有一个数据指针,在初始状态下指向的是首记录,利用fetch语句可以移动该指针,从而对游标中 ...
- Mysql视图的作用及其性能分析
定义:视图是从一个或几个基本表导出的表,它与基本表不同,是一个虚表. 作用: 1.简化操作,不用进行多表查询. 2.当不同种类的用用户共享同一个数据库时,非常灵活,(用户以不同的 方式看待同一数据. ...
- MYSQL视图的学习笔记
MYSQL视图的学习笔记,学至Tarena金牌讲师,金色晨曦科技公司技术总监沙利穆 课程笔记的综合. 视图及图形化工具 1. 视图的定义 视图就是从一个或多个表中,导出来的表,是一个虚 ...
- 深入解析MySQL视图view
阅读目录---深入解析MySQL视图view 创建视图 查看视图 视图的更改 create or replace view alter DML drop 使用with check option约束 嵌 ...
- MySQL视图view/存储过程和函数的使用
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "Helvetica Neue"; color: #454545 } p. ...
- MySQL视图更新
昨天在写美团2019秋招笔试题的时候遇到了关于视图是否能更新的问题,突然感觉这个问题之前复习的时候重点关注过,但是却又想不全.今天特地搜了一些资料总结一下.本文主要说明视图的更新限制,如需关于视图的更 ...
- 一个MySQL视图的优化过程
1.需要优化的sql 最近做一个基于.net mvc和MySQL的仓储系统的优化工作,遇到了一个执行特别慢的SQL语句,经过一番折腾,终于搞定啦,分享一下过程.问题就是下面这个家伙: create o ...
- mysql视图和临时表的区别
视图 视图是由从数据库的基本表中选出来的数据组成的逻辑窗口,它与基本表不同的是,视图是一个虚表.数据库中只存放视图的定义,而不存放视图包含的数据,这些数据仍存放在原来的基表中.所以基表中的数据如果发生 ...
- MySQL视图(view)
一.基本概念 视图是一个虚拟表,是sql的查询结果,其内容由查询定义.同真实的表一样,视图包含一系列带有名称的列和行数据,在使用视图时动态生成.视图的数据变化会影响到基表,基表的数据变化也会影响到视图 ...
- 11.Mysql视图
11.视图11.1 什么是视图 视图view是一张虚拟表,它不存储数据,数据仍在表里,视图由一条查询表的select语句创建,视图只存储select语句. 可以将复杂的查询语句封装成视图,用户可以从视 ...
随机推荐
- 第12章 Reference-RIL运行框架
Reference-RIL完成两部分处理逻辑: 与LibRIL交互完成RIL消息的处理. 与Modem通信模块交互完成AT命令的执行. Reference-RIL的运行机制 主要涉及以下几个方面: R ...
- 安卓权威编程指南-笔记(第27章 broadcast intent)
本章需求:首先,让应用轮询新结果并在有所发现时及时通知用户,即使用户重启设备后还没有打开过应用.其次,保证用户在使用应用时不出现新结果通知. 1. 一般intent和broadcast intent ...
- nginx设置目录浏览及中文乱码问题解决
在Nginx下默认是不允许列出整个目录的.如需此功能, 先打开nginx.conf文件,在location server 或 http段中加入 autoindex on;另外两个参数最好也加上去: a ...
- PHP文件上传 (以上传txt文件为例)
1.前端代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <ti ...
- 前端每日实战:102# 视频演示如何用纯 CSS 创作一个小和尚
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/oMmYXp 可交互视频 此视频是可 ...
- 小程序自定义switch组件
如上图,小程序api中的switch组件只能自定义颜色,不能自定义宽高,所以就开始了自己写switch组件. 自定义组件样式 switch组件样式大致如图,样式思路:未选中时为一个长方形有圆角按钮,和 ...
- vue项目开发,用webpack配置解决跨域问题
今天在本地开发时候碰到了跨域的问题,突然觉着跨域问题在所难免啊,之前没有没有碰到总觉着解决跨域很高大上的样纸,其实就是受限于网络的同源策略,跨域前后端都可以进行处理. 1,后端更改header hea ...
- GPS授时器简介
GPS授时器简介 GPS是全球定位系统的简称.GPS定位卫星在全球范围内进行定位.导航的系统.GPS所具有的全天候.高精度和自动测量的特点,已经融入到国民经济建设.国防建设和社会发展的各个领域.而在授 ...
- python使用while循环实现九九乘法表
a = 1while a <= 9: b = 1 while b <= a: print("%d*%d=%d\t" % (b, a, a * b), end=" ...
- RAC修改VIP地址
目录 当前环境 1.通过[srvctl config]确认当前VIP地址. 2.关闭dbconsole[对应的em] 3.关闭数据库实例 4.关闭asm实例 5.关闭结点服务 6.修改两个节点的/et ...