视图

几个表合并之后用视图来表示他们,通过视图来查询连接表里面的数据信息。

一、视图的定义

视图就是一条SELECT语句执行后返回的结果集。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

 

二、视图的特性

视图是对若干张基本表的引用,一张虚表,查询语句执行的结果,不存储具体的数据(基本表数据发生了改变,视图也会跟着改变);

可以跟基本表一样,进行增删改查操作(ps:增删改操作有条件限制);

 

三、视图的作用

方便操作,特别是查询操作,减少复杂的SQL语句,增强可读性;

更加安全,数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别;

 

四、使用场合

权限控制的时候,不希望用户访问表中某些含敏感信息的列,比如salary...

关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作。

 

五、视图增删改查的案例

  • 创建视图

视图视图

视图

 

DROP VIEW IF EXISTS qw;
CREATE ALGORITHM = UNDEFINED DEFINER = `root` @`localhost` SQL SECURITY DEFINER VIEW qw AS 
(SELECT 
  emp.`ename` AS NAME,
  dept.`dname` AS d,
  job.`jname` AS j
FROM
  (
    emp 
    LEFT JOIN dept 
      ON emp.`dept_id` = dept.`id`
  ) 
  LEFT JOIN job 
    ON job.`id` = emp.`job_id`) ;
    

 

几点说明(MySQL中的视图在标准SQL的基础之上做了扩展):

ALGORITHM=UNDEFINED:指定视图的处理算法;

DEFINER=`root`@`localhost`:指定视图创建者;

SQL SECURITY DEFINER:指定视图查询数据时的安全验证方式

 

通过创建的视图来查询我们所需要的信息

1 SELECT qw.d,qw.j FROM qw WHERE qw.NAME = '猪八戒' ;

视图

 

  • 增删改操作

注意:不能一张由多张关联表连接而成的视图上同时做两张表操作

视图与表是一对多关系情况:如果只修改一张表的数据,且没有其它约束(如视图中没有的字段,在基本表中是必填字段情况),是可以进行改数据操作,如以下语句,操作成功。

上一篇:MySQL数据库01


下一篇:基本sql语句