mysql视图概念
视图本身是一张虚拟表,不存放任何数据。在使用sql语句访问视图的时候,获取的数据是mysql从其它表中生成的,视图和表在同一个命名空间。视图查询数据相对安全,可以隐藏一些数据和结构,只让用户看见权限内的数据,使复杂的查询易于理解和使用。
视图用法
如下基于用户和订单管理演示视图的基本用法。(在线学习视频教程分享:mysql视频教程)
基础表结构
create table v01_user ( id int(11) not null auto_increment comment '主键id', user_name varchar(20) default null comment '用户名', phone varchar(20) default null comment '手机号', pass_word varchar(64) default null comment '密码', card_id varchar(18) default null comment '身份证id', pay_card varchar(25) default null comment '卡号', primary key (id)) engine=innodb default charset=utf8 comment '用户表';create table v02_order ( id int(11) not null auto_increment comment '主键id', user_id int(11) not null comment '用户id', order_no varchar(32) default null comment '订单编号', good_name varchar(60) default null comment '商品名称', good_id int(11) default null comment '商品id', num int(11) default null comment '购买数量', total_price decimal(10,2) default null comment '总价格', primary key (id)) engine=innodb default charset=utf8 comment '订单表';
基本语法
create or replace view view_name as select_statement
注意事项:表和视图共享数据库中相同的名称空间,因此,数据库不能包含具有相同名称的表和视图。
用户订单视图
create or replace view user_order_view as select t1.id,t1.user_name,t2.order_no,t2.good_id, t2.good_name,t2.num,t2.total_pricefrom v01_user t1left join v02_order t2 on t2.user_id = t1.id;
视图调用
这里和mysql的表查询基本一致,可以使用各种查询条件。
select * from user_order_view where user_name='cicada';查看视图show create view user_order_view ;修改视图alter view view_name as select_statement ;删除视图drop view [if exists] view_name ;
视图更新
在指定条件允许的情况下,可以通过在视图上操作更新,删除,甚至写入数据,进而更新视图所涉及的相关表。
update user_order_view set user_name='smile' where id='1';
这里就通过对视图执行更新操作,进而更新v01_user表数据。如果视图定义时使用聚合函数,分组等特殊操作,则无法更新。mysql不支持在视图上创建触发器。
视图实现
1、临时表算法
服务器会把视图查询sql的数据保存在临时表中,临时表的结构和视图字段结构一致,这样是sql查询优化中最忌讳的操作,数据量稍微偏大,就会严重影响性能。如果视图无法和原有表产生一对一的映射关系,就会产生临时表,由此也可见视图并不是很简单,甚至是非常复杂的功能。
2、合并算法
服务器基于视图中使用的表执行查询,最后把查询结构合并后返回给客户端。
3、区别方法
执行如下查询语句,可以分析执行的性能参数。
explain select * from user_order_view ;
观察查询结果中select_type字段,如果是derived则说明使用临时表。这里sql执行分析的语法后面优化部分再详解。
注意事项
1、性能问题
mysql并不支持在视图中创建索引,使用视图的时候可能会引发很多查询性能问题,所以建议使用的时候要慎重,多角度审视和测试。
2、特殊用法
基于视图的查询,可以修改部分表结构,只要不是在视图中使用的字段,就不会影响视图的查询。
相关文章教程推荐:mysql教程
以上就是一文详解mysql视图的详细内容。