本文摘自PHP中文网,作者V,侵删。

mysql视图概念
视图本身是一张虚拟表,不存放任何数据。在使用SQL语句访问视图的时候,获取的数据是MySQL从其它表中生成的,视图和表在同一个命名空间。视图查询数据相对安全,可以隐藏一些数据和结构,只让用户看见权限内的数据,使复杂的查询易于理解和使用。
视图用法
如下基于用户和订单管理演示视图的基本用法。(在线学习视频教程分享:mysql视频教程)
基础表结构
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | 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 '订单表' ;
|
基本语法
1 2 | CREATE OR REPLACE VIEW view_name
AS select_statement
|
注意事项:表和视图共享数据库中相同的名称空间,因此,数据库不能包含具有相同名称的表和视图。
用户订单视图
1 2 3 4 5 | 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_price
FROM v01_user t1
LEFT JOIN v02_order t2 ON t2.user_id = t1.id;
|
视图调用
这里和MySQL的表查询基本一致,可以使用各种查询条件。
1 2 3 4 5 6 7 | 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 ;
|
视图更新
在指定条件允许的情况下,可以通过在视图上操作更新,删除,甚至写入数据,进而更新视图所涉及的相关表。
1 | UPDATE user_order_view SET user_name= 'smile' WHERE id= '1' ;
|
这里就通过对视图执行更新操作,进而更新v01_user表数据。如果视图定义时使用聚合函数,分组等特殊操作,则无法更新。MySQL不支持在视图上创建触发器。
视图实现
1、临时表算法
服务器会把视图查询SQL的数据保存在临时表中,临时表的结构和视图字段结构一致,这样是SQL查询优化中最忌讳的操作,数据量稍微偏大,就会严重影响性能。如果视图无法和原有表产生一对一的映射关系,就会产生临时表,由此也可见视图并不是很简单,甚至是非常复杂的功能。
2、合并算法
服务器基于视图中使用的表执行查询,最后把查询结构合并后返回给客户端。
3、区别方法
执行如下查询语句,可以分析执行的性能参数。
1 | EXPLAIN SELECT * FROM user_order_view ;
|
观察查询结果中select_type字段,如果是DERIVED则说明使用临时表。这里SQL执行分析的语法后面优化部分再详解。
注意事项
1、性能问题
MySQL并不支持在视图中创建索引,使用视图的时候可能会引发很多查询性能问题,所以建议使用的时候要慎重,多角度审视和测试。
2、特殊用法
基于视图的查询,可以修改部分表结构,只要不是在视图中使用的字段,就不会影响视图的查询。
相关文章教程推荐:mysql教程
以上就是一文详解mysql视图的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
mysql的索引优化如何使用
mysql中加减乘除与求余和求平均值以及查询不等于某数值的实例
关于mysql max 与 where 间的执行问题小结
数据库查询语句select有什么用?
mysql怎么删除数据表中的行数据(记录)?
分析mysql抛出异常的几种常见解决方式
myeclipse连接mysql数据库详细步骤
十个mysql中基本语句优化的原则
mysql中普通、慢查询日志的区别
navicat如何查看mysql的操作记录
更多相关阅读请进入《mysql》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 一文详解mysql视图