• mysql-视图/存储过程/触发器


    视图

    视图( View )是一种虚拟存在的表。视图中的数据并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。
    通俗的讲,视图只保存了查询的 SQL 逻辑,不保存查询结果。所以我们在创建视图的时候,主要的工作就落在创建这条SQL 查询语句上。

    语法

    1). 创建

    1. CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH [
    2. CASCADED | LOCAL ] CHECK OPTION ]

    2). 查询

    1. 查看创建视图语句:SHOW CREATE VIEW 视图名称;
    2. 查看视图数据:SELECT * FROM 视图名称 ...... ;

    3). 修改

    1. 方式一:CREATE [OR REPLACE] VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH
    2. [ CASCADED | LOCAL ] CHECK OPTION ]
    3. 方式二:ALTER VIEW 视图名称[(列名列表)] AS SELECT语句 [ WITH [ CASCADED |
    4. LOCAL ] CHECK OPTION ]

    4). 删除

    DROP VIEW [IF EXISTS] 视图名称 [,视图名称] ...
    1. -- 创建视图
    2. create or replace view stu_v_1 as select id,name from student where id <= 10;
    3. -- 查询视图
    4. show create view stu_v_1;
    5. select * from stu_v_1;
    6. select * from stu_v_1 where id < 3;
    7. -- 修改视图
    8. create or replace view stu_v_1 as select id,name,no from student where id <= 10;
    9. alter view stu_v_1 as select id,name from student where id <= 10;
    10. -- 删除视图
    11. drop view if exists stu_v_1;

    检查选项

    当使用 WITH CHECK OPTION 子句创建视图时, MySQL 会通过视图检查正在更改的每个行,例如 插 入,更新,删除,以使其符合视图的定义。 MySQL 允许基于另一个视图创建视图,它还会检查依赖视 图中的规则以保持一致性。为了确定检查的范围,mysql 提供了两个选项: CASCADED LOCAL ,默认值为 CASCADED

    1). CASCADED

    比如, v2 视图是基于 v1 视图的,如果在 v2 视图创建的时候指定了检查选项为 cascaded ,但是 v1 视图创建时未指定检查选项。 则在执行检查时,不仅会检查v2 ,还会级联检查 v2 的关联视图 v1

    2). LOCAL

    比如, v2 视图是基于 v1 视图的,如果在 v2 视图创建的时候指定了检查选项为 local ,但是 v1 视图创
    建时未指定检查选项。 则在执行检查时,知会检查 v2 ,不会检查 v2 的关联视图 v1

    视图的更新

    要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一 项,则该视图不可更新:
    A. 聚合函数或窗口函数( SUM() MIN() MAX() COUNT() 等)
    B. DISTINCT
    C. GROUP BY
    D. HAVING
    E. UNION 或者 UNION ALL
    create view stu_v_count as select count(*) from student;
    上述的视图中,就只有一个单行单列的数据,如果我们对这个视图进行更新或插入的,将会报错。

    视图作用

    1). 简单

    视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。

    2). 安全

    数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据

    3). 数据独立

    视图可帮助用户屏蔽真实表结构变化带来的影响。
    创建视图会生成新的可视化类似table之类的东西。
  • 相关阅读:
    关于 头歌平台 复制限制解除的方法
    Python爬虫实战(基础篇)—14获取【巴黎圣母院新闻网(Notre Dame News)】新闻写入Word(附完整代码)
    SpringBoot+Vue项目大学生网络教学平台的设计与实现
    CentOS to KeyarchOS 系统迁移体验
    字符串 --- 不可变性与驻留池
    第08章 MyBatisPlus持久化操作(二)
    单片机学习--->Keil多文件工程
    Linq-20220817更新
    java计算机毕业设计售楼系统MyBatis+系统+LW文档+源码+调试部署
    带团队后的日常思考(八)
  • 原文地址:https://blog.csdn.net/weixin_71113035/article/details/139335667