• mysql view


    定义:在 SQL 中,视图是基于 SQL 语句的结果集的可视化的表。

    1、视图是一个虚拟存在的表,视图可以包含表的全部或者部分记录,也可以由一个表或者多个表来创建。使用视图就可以不用看到数据表中的所有数据,而是只想得到所需的数据。当我们创建一个视图的时候,实际上是在数据库里执行了SELECT语句,SELECT语句包含了字段名称、函数、运算符,来给用户显示数据。

    2、视图在外观上和很相似,但是它不需要实际上的物理存储数据还是存储在原来的表里。在数据库中,只存放了视图的定义,并没有存放视图的数据,视图的数据是依赖原来表中的数据的,所以原来的表的数据发生了改变,那么显示的视图的数据也会跟着改变,例如向数据表中插入数据,那么在查看视图的时候,会发现视图中也被插入了同样的数据。视图实际上是由预定义的查询形式的表所组成的。

    3、在数据库中,视图的使用方式与表的使用方式一致,我们可以像操作表一样去操作视图,或者去获取数据。一般来说,我们只是利用视图来查询数据,不会通过视图来操作数据。

    4、基于视图可以创建视图

    5、视图增加了数据的安全性和逻辑独立性,数据库的设计和结构不会受到视图中的函数、where 或 join 语句的影响。视图可以只展现数据表的一部分数据,对于我们不希望让用户看到全部数据,只希望用户看到部分数据的时候,可以选择使用视图。

    用法:

    1、创建视图(CREATE VIEW 视图名称[(column_list)] AS SELECT 语句)

    create view employee_view as SELECT * from employee;

    完整的创建视图的格式

    CREATE ALGORITHM VIEW 视图名称[(column_list)] AS SELECT 语句  WITH  [CASCADED|LOCAL] CHECK OPTION

      1)CASCADED 默认值,表示更新视图的时候,要满足视图和表的相关条件

      2)LOCAL:表示更新视图的时候,要满足该视图定义的一个条件即可

    
    
    create view employee_view as SELECT * from employee WITH CASCADED CHECK OPTION;

    看到很多例子,更新视图可以更新真实表。原因,我是这样理解的:视图并没有保存内容。只是引用数据。那么,更新视图,其实就是以引用的方式操作了真实表
    with check option:对视图进行更新操作的时,需要检查更新后的值是否还是满足视图公式定义的条件。通俗点,就是所更新的结果是否还会在视图中存在。如果更新后的值不在视图范围内,就不允许更新如果创建视图的时候,没有加上with check option,更新视图中的某项数据的话,mysql并不会进行有效性检查。删掉了就删掉了。在视图中将看不到了。所以使用WHIT [CASCADED|LOCAL] CHECK OPTION选项可以保证数据的安全性

    2、查看视图数据(select column_list from view)

    SELECT * FROM employee_view;

    3、查看视图(show create view view_name)

     show CREATE view employee_view;

    4、删除视图(drop view view_name)

    drop view employee_view

    5、修改视图

      1)CREATE OR REPLACE VIEW 视图名称[(column_list)] AS SELECT 语句

    create or replace view employee_view as select eid,ename,salary FROM employee;

      2)ALTER VIEW视图名称[(column_list)] AS SELECT 语句

    alter view employee_view as SELECT * FROM employee;

    6、修改视图中的数据(update view_name set column where 语句)

    UPDATE employee_view set ename='小红' WHERE ename='小个';
  • 相关阅读:
    python's eithteenth day for me 面向对象——命名空间
    python's seventeenth day for me 面向对象
    python's sixteenth day for me 员工信息表
    python's fifteenth day for me 递归函数
    python's fourteenth day for me 内置函数
    用装饰器做一个登陆功能(进阶):
    装饰器 为多个函数加上认证功能(账号密码来源于文件),要求只要登陆成功一次,后续函数则无需登陆。
    python's thirteenth day for me 迭代器 生成器
    php函数
    php日期格式
  • 原文地址:https://www.cnblogs.com/sker/p/5765042.html
Copyright © 2020-2023  润新知