MYSQL中的视图
1.1. MySQL 视图
什么是视图
通俗的讲,视图就是一条SELECT语句执行后返回的结果集。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。
视图的特性
视图是对若干张基本表的引用,一张虚表,查询语句执行的结果,不存储具体的数据(基本表数据发生了改变,视图也会跟着改变);
可以跟基本表一样,进行增删改查操作(ps:增删改操作有条件限制);
视图的作用
方便操作,特别是查询操作,减少复杂的SQL语句,增强可读性;
更加安全,数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别;
使用场合
权限控制的时候,不希望用户访问表中某些含敏感信息的列,比如salary...
关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作,不用每次操作都进行关联查询
1.1.1. 如何创建视图
CREATE VIEW 视图名 as SELECT 查询语句
1.1.2. 视图的使用
视图创建好了之后,我们可以将该视图当成是一张表来使用,进行相关的增删改查操作,但一般仅针对视图进行查询操作。
l 不能在一张由多张关联表连接而成的视图上做同时修改两张表的操作
l 视图与表是一对一关系情况:如果没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行增删改数据操作,但不推荐。