1.视图
视图类似于表,但不是真实存在的表,而是根据已存在的表创建出来的虚拟表,即它并不会被保存在物理磁盘上。视图的使用场景很多,比如说,你需要给某个用户提供某张表的访问权限,但又不能把所有字段都给他看,这时候我们可以创建一个视图,选取那张表或多张表的某些字段创建一个视图,然后把查看视图的权限开放给他即可达到保护数据安全的作用。
2.创建视图
2.1 查看权限
想要操作视图,得先看一下当前用户有没有相关的权限,比如说创建视图权限、查看视图权限、选择权限、删除权限等,这些信息可以在mysql.user找到
select`user`,Select_priv,Create_view_priv,Show_view_priv from mysql.user;
2.2 创建视图
确定自己又创建视图的权限之后,可以使用下面的语句创建视图,注意视图类似于表,所以视图名必须是唯一存在的,不能与已有的表名或视图名重复
createview 视图名 as 选择语句;
select语句就是我们平时查询表数据的语句,可以从单个表查询,也可以使用join从多个表查询
如果该视图已经存在,你可以使用 or replace 语句覆盖已存在的视图
createorreplaceview 视图名 asSelect语句;
3.查看视图
3.1 查看视图
创建出来的视图类似于表,所以你听可以通过show tables查看所有表和视图
showtables;
但show tables查询出来的你也不知道哪个是视图哪个是表,如果你想只看视图而不看表,下面两个语句都能过滤出所有视图
showtablestatuswherecomment='view';select*from information_schema.views;
如果你想看视图的字段结构,与查看表的字段是一样的,可以使用describe或者简写desc
describe 视图名;desc 视图名;
3.2 查看创建视图语句
如果想查看一个视图是如何创建出来的,可以使用show命令,但是前提是当前用户有
showcreatetable 视图名;showcreateview 视图名;
4.修改视图
视图是根据基本表创建的,如果基本表的列结构发生变化,比如说基本表的某个列名发生了改变,则视图会报错提示查不到该列,所以需要重新。
更新视图其实就是重新选择一次原表数据,不过这次不是重新创建视图而是修改视图,所以使用alter view命令
alterview 视图名 asSelect语句;
视图不能直接重命名,你可以选择删掉重建,或者直接使用create or replace view命令
还要注意,alter view命名要求用户除了就有select权限,还要具有create view和drop权限
5.删除视图
删除视图与删除表差不多,使用drop view命令
dropview 视图名;
要注意,删除视图只能删除视图的定义,不会删除数据,因为数据存储在基本表里
6.视图的增删改查
视图类似一张表,所以对视图的增删改查操作的语句与对表的增删改查的语句是一样的,这里就不一样列举了。要注意,因为视图并不真实存在,所以对视图的操作基本上就是对基本表的操作,比如说增加、删除、修改视图的数据,其实就是增删改基本表的数据。
但我要提醒的是,并不是所有视图都是可以修改更新的,如果视图包含以下结构中的任何一种,它就是不可更新的,比如说下面几种情况(可能还有其他其他情况)
- 使用了sum、max等聚合函数
- 使用了distinct、group by、having、union或者union all等操作
- select查询语句中包含了子查询
- from一个不能更新的视图
- where子句的子查询引用了from子句中的表
版权归原作者 冰冷的希望 所有, 如有侵权,请联系我们删除。