视图
首页->学习资料->微服务治理->sql教程 关键词: 发布时间:2014-12-22 09:32:02 浏览次数:1528

视图,是一张表,但是虚拟表!

是通过一条查询语句得到一个张虚拟表!

因此,认为视图,就是 select语句的结果!也可以理解为视图里存储的是一条查询sql语句

 

语法:

create view 视图名字 AS 查询语句

比如:查找班里的最高最富的同学;

select * from student where (height,money)=(select max(height),max(money) from student);

这样写比较长,如果先建立一个视图:

create view view_gf as select * from student where (height,money)=(select max(height),max(money) from student);

那么我们现在通过视图查询一样可以得到相同的结果:

select * from view_gf;

看,语句是不是变得很简单了;


视图的作用

可见,使用视图的功能之一,就是简化查询的业务逻辑!

注意:视图内是不保存真实数据的!视图内,只有一条形成视图的 select 语句而已!

因此,每次从视图查询时,都需要利用视图,再在真实的表内将数据查询到!

类似一个 from型子查询!


 

 

功能之二:隐藏真实的表结构! (在视图中将字段用as别名代替,达到隐藏真实字段名的作用)

从而取得更大的兼容性

总结作用:1,简化逻辑,2,因此真实的结构(兼容性,限制用户的处理)

 

 

视图算法,执行方式

例子:取得每个班级最高的学生信息(当同班有相同身高且均为最高时)

使用 from型子查询,可以,但是使用同样逻辑的视图不行!

用子查询:可以查到同班最高且身高一样的多名同学

select * from student where height in(select max(height) as height from student group by classid);

但是用当用此子查询建立视图后:

create view view_height as select * from student where height in(select max(height) as height from student group by classid);

通过视图查询得到相同结果:

select * from view_height;


但是如果视图建立不适当时,可能出现重复的值,有时候会出现查询结果不匹配:

 

视图其实一共有三种执行方式:

merge,合并

temptable,临时表

undefined,未定义,就是默认的,mysql自己决定算法(从merge,和temptable内选择)!

 

典型的都是选择的merge的:

 

如何解决?

可以选择决定视图的算法!在创建视图时,指定。

ALGORITHM=temptable即可


algorithm

用到比较少!


赞:(0)
踩:(0)
相关文章
find_in_set在集合中查找
sql查询自定义排序field函数
sql显示表结构及索引
sql修改表
添加、删除索引
sql分组
sql子查询
sql多表更新
sql建表同时插入数据
sql多表删除
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:946734
粤ICP备18028092号-1  微信:hurong241