一、简介
视图:MySQL从5.0.1版本开始提供视图功能。
一种虚拟存在的表,行和列的数据来自 定义视图 的查询中使用的表 ,并且是在使用视图时动态生成的,只保存了sql逻辑,不 保存查询结果
应用场景:
– 多个地方用到同样的查询结果
– 该查询结果使用的sql语句较复杂
示例:
案例 查询姓张的学生名和专业名
SELECT stuname,majorname
FROM stuinfo s
INNER JOIN major m
ON s.majorid = m.id
WHERE s.stuname LIKE '张%';
视图版:把经常使用的语句封装起来。
CREATE VIEW v1
AS
SELECT stuname,majorname
FROM stuinfo s
INNER JOIN major m
ON s.majorid = m.id;
SELECT * FROM v1 WHERE stuname LIKE '张%';
视图的优点:
• 重用sql语句
• 简化复杂的sql操作,不必知道它的查询细节
• 保护数据,提高安全性
二、视图的创建
创建视图的语法:
create [or replace] view view_name
As select_statement
[with|cascaded|local|check option]
三、视图的修改
修改视图的语法:
create or replace view view_name
As select_statement
[with|cascaded|local|check option]
语法2:
alter view view_name
As select_statement
[with|cascaded|local|check option]
四、视图的查看和删除
查看视图的语法:
show tables;
如果需要查询某个视图的定义,可以使用show create view
命令进行查看:
show create view view_name \G
删除视图的语法:
用户可以一次删除一个或者多个视图,前提是必须有该视
图的drop权限。
drop view [if exists] view_name,view_name …[restrict|cascade]
五、视图的更新
视图的可更新性和视图中查询的定义有关系,以下类型的视图是不能更新的。
• 包含以下关键字的sql语句:分组函数、distinct、group by 、having、union或者union all
• 常量视图
• Select中包含子查询
• join
• from一个不能更新的视图
• where子句的子查询引用了from子句中的表
六、视图和表的对比
视图语法:create view
表语法:create table
视图没有实际占用物理空间,只是保存了SQL逻辑;
表占用了物理空间,保存了数据。
视图可以增删改查,但一般是查;
表可增删改查。