zoukankan      html  css  js  c++  java
  • [转]mysql 视图

    转载自http://blog.csdn.net/evankaka/article/details/47071133

    一. 视图概述

    视图是一个虚拟表,其内容由查询定义。带来许多好处:

    1、 视图能简化用户操作

    2、 视图使用户能以多种角度看待同一数据

    3、 视图对重构数据库提供了一定程度的逻辑独立性

    4、视图能够对机密数据提供安全保护

    5、适当的利用视图可以更清晰地表达查询

    二、使用案例

    在创建视图前应先看看是否有权限:

    实例:

    //创建单表视图

    CREATE VIEW V_VIEW1(ID, NAME, SEX, AGE,DEPARTMENT) AS 

    SELECT ID, NAME, SEX, AGE,DEPARTMENT 

    FROM learning.t_employee;  

    //显示视图结果

    SELECT * FROM V_VIEW1 

    //创建多表视图

    CREATE VIEW V_VIEW2(ID, NAME, SEX, AGE,DEPARTMENT,POS,EXPERENCE) AS 

    SELECT a.ID, a.NAME, a.SEX, a.AGE,a.DEPARTMENT,b.POS,b.EXPERENCE 

    FROM learning.t_employee a,learning.t_employee_detail b 

    WHERE a.ID=b.ID;  

    //查看视图

    DESCRIBE V_VIEW2

    //修改视图

    CREATE OR REPLACE VIEW V_VIEW1(ID, NAME, SEX) AS 

    SELECT ID, NAME, SEX  

    FROM learning.t_employee;  

    //更新视图,同样会修改原表数据

    UPDATE V_VIEW2 

    SET POS='高级@程师' 

    WHERE NAME='天@'  

    //删除视图

    DROP VIEW IF EXISTS 视图名  

    不可更新的视图:
    某些视图是可更新的。也就是说,可以在诸如UPDATE、DELETE或INSERT等语句中使用它们,以更新基表的内容。对于可更新的视图,在视图中的行和基表中的行之间必须具有一对一的关系。还有一些特定的其他结构,这类结构会使得视图不可更新。更具体地讲,如果视图包含下述结构中的任何一种,那么它就是不可更新的:

    · 聚合函数(SUM(), MIN(), MAX(), COUNT()等)。
    · DISTINCT
    · GROUP BY
    · HAVING
    · UNION或UNION ALL
    · 位于选择列表中的子查询
    · Join
    · FROM子句中的不可更新视图
    · WHERE子句中的子查询,引用FROM子句中的表。
    · 仅引用文字值(在该情况下,没有要更新的基本表)。
    · ALGORITHM = TEMPTABLE(使用临时表总会使视图成为不可更新的)。

    注意

    视图中虽然可以更新数据,但是有很多的限制。一般情况下,最好将视图作为查询数据的虚拟表,而不要通过视图更新数据。因为,使用视图更新数据时,如果没有全面考虑在视图中更新数据的限制,就可能会造成数据更新失败。

    CREATE VIEW V_VIEW3(ID, NAME,SEX,AGE,DEPARTMENT,SALARY, HOME, MARRY, HOBBY) AS 
    SELECT ID, NAME, SEX,AGE,DEPARTMENT,SALARY,HOME,MARRY,HOBBY 
    FROM learning.t_employee WHERE DEPARTMENT='人事部' 
    WITH LOCAL CHECK OPTION;  

    //表示只限定插入部门为人事部的人。


    然后插入一条:

    INSERT INTO learning.V_VIEW3(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) 

    VALUES(NULL,'会会会会','女',20,'人事部','4500','广东','否','网球');  

    看下结果:SELECT * FROM learning.V_VIEW3  

     //插入成功

    再来插入一条:

    INSERT INTO learning.V_VIEW3(ID, NAME, SEX, AGE,DEPARTMENT, SALARY, HOME, MARRY, HOBBY) 

    VALUES(NULL,'qqqqvasvas','女',20,'研发部','4500','上海','否','网球');  

    结果显示插入失败


    对于with check option用法,总结如下:
    通过有with check option选项的视图操作基表(只是面对单表,对连接多表的视图正在寻找答案),

    有以下结论: 插入后的数据,通过视图能够查询出来就符合WITH CHECK OPTION 否则就不符合;


    首先视图只操作它可以查询出来的数据,对于它查询不出的数据,即使基表有,也不可以通过视图来操作。


    1.对于update,有with check option,要保证update后,数据要被视图查询出来
    2.对于delete,有无with check option都一样
    4.对于insert,有with check option,要保证insert后,数据要被视图查询出来
    对于没有where 子句的视图,使用with check option是多余的

  • 相关阅读:
    并不对劲的bzoj3932: [CQOI2015]任务查询系统
    并不对劲的bzoj4868: [Shoi2017]期末考试
    并不对劲的bzoj1853:[SCOI2010]幸运数字
    并不对劲的bzoj4199: [Noi2015]品酒大会
    并不对劲的bzoj1500: [NOI2005]维修数列
    并不对劲的hdu4777
    并不对劲的线段树套平衡树
    44.Linked List Cycle II(环的入口节点)
    43.Word Break(看字符串是否由词典中的单词组成)
    42.Flatten Binary Tree to Linked List
  • 原文地址:https://www.cnblogs.com/alamZ/p/6252670.html
Copyright © 2011-2022 走看看