一、什么是视图?
视图是一个虚拟表,它是一个虚拟表,它不在数据库中以存储的形式保存(本身不包含数据),是在使用视图的时候动态生成。
二、视图的优点?
1、提高查询效率
数据库中的数据查询非常复杂,可以简化sql语句
2、安全
有些保密字段,可以通过创建视图限制用户对某些字段进行操作
3、简单
不需要关心后面对应的表结构
三、视图的缺点?
1、性能差
把视图查询结果转换成对表的查询
2、修改限制
修改视图数据,必须把它转化为对基础表的修改
(二)视图的运用
1、创建一个视图:
格式:create view 视图名 as (sql语句)
案例:CREATE VIEW sthz as( select * from dept ,emp where dept.dept1=emp.dept2);
2、查询数据库中所有的表 (物理表中是没有视图)
show tables ;
3、查看视图名
格式:select * from 视图名
4、查看创建的视图(包含创建语句和视图名称,编码格式)
格式:show create view 视图名
案例:show create view sthz ;
5、删除视图
格式:drop view 视图名 ;
案例 :drop view sthz;
视图特点:
1、视图是由基础表产生的虚拟表
2、视图的创建不影响基础表
3、 删除视图不影响基础表
4、视图删除数据,基础表也同时删除数据(合表的表无法删除,单表可以删除)
5、基础表删除数据,视图也同时删除
6、视图不能修改表字段,不能对表字段删除