⑩④【MySQL】什么是视图?怎么用?视图的检查选项? 视图的作用?[VIEW]

在这里插入图片描述

个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~
个人主页:.29.的博客
学习社区:进去逛一逛~

在这里插入图片描述

视图VIEW

  • ⑩④详解MySQL视图
    • 1. 视图的基本使用
    • 2. 视图的检查选项
    • 3. 视图的更新
    • 4. 视图的作用


⑩④详解MySQL视图


1. 视图的基本使用

视图

  • 什么是视图?

    • 视图(View)是一种虚拟存在的表。视图中的数据并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。
  • 如何使用视图?

  • 🚀创建视图:

    • CREATE [OR REPLACE] VIEW 视图名称[(字段列表)] AS SELECT语句 [WITH [CASCADE | LOCAL] CHECK OPTION];
      
      • -- 演示-- CREATE OR REPLACE 表示要创建或替换一个视图
        -- 根据查询结果创建一个视图
        CREATE OR REPLACE VIEW emp_v_1 
        AS SELECT id,name,age 
        from emp where id < 10;
        
  • 🚀查询视图:

    • -- 查看创建视图的语句
      SHOW CREATE VIEW 视图名称;-- 查看视图所有数据(与查询表数据一致)
      SELECT * FROM 视图名称; 
      
  • 🚀修改视图:

    • -- 方式一:
      CREATE OR REPLACE VIEW 视图名称[(字段列表)] AS SELECT语句 [WITH [CASCADE | LOCAL] CHECK OPTION];-- 方式二:
      ALTER VIEW 视图名称[(字段列表)] AS SELECT语句 [WITH [CASCADE | LOCAL] CHECK OPTION];
      
      • -- 演示
        -- 存在视图emp_v_1,包含字段id,name,age ,根据喜好更新-- 方式一:
        CREATE OR REPLACE VIEW emp_v_1 
        AS SELECT id,name,job
        from emp where id > 5;-- 方式二:
        ALTER VIEW emp_v_1 
        AS SELECT id,name,job
        from emp where id < 8;
  • 🚀删除视图:

    • -- IF EXISTS关键字,表示只有视图存在时才删除,视图不存在则不执行删除。
      DROP VIEW [IF EXISTS] 视图1 [,视图2,视图3...];
      
      • -- 演示-- 删除视图emp_v_1 
        DROP VIEW IF EXISTS emp_v_1;
        



2. 视图的检查选项

视图检查选项 - WITH [CASCADE | LOCAL] CHECK OPTION

  • 视图检查选项:

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

    • -- 创建或修改视图,设置检查选项,范围:CASCADE
      CREATE OR REPLACE VIEW 视图名称[(字段列表)] AS SELECT语句 WITH CASCADE CHECK OPTION;-- 修改视图,设置检查选项,范围:CASCADE
      ALTER VIEW 视图名称[(字段列表)] AS SELECT语句 WITH CASCADE CHECK OPTION;
      
    • image-20231114195452384

  • 🚀LOCAL

    • -- 创建或修改视图,设置检查选项,范围:LOCAL
      CREATE OR REPLACE VIEW 视图名称[(字段列表)] AS SELECT语句 WITH LOCAL CHECK OPTION;-- 修改视图,设置检查选项,范围:LOCAL
      ALTER VIEW 视图名称[(字段列表)] AS SELECT语句 WITH LOCAL CHECK OPTION;
      
    • LOCAL检查选项会递归检查当前视图依赖的视图的规则,若依赖的视图也设置了检查选项,保持规则一致性,若依赖的视图并未设置依赖选项,不检查其规则,无需保持规则一致性。




3. 视图的更新

视图的更新规则

  • 要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系。如果视图包含以下任何一项,则该视图不可更新

    • 聚合函数窗口函数(SUM()、MIN()、MAX()、COUNT()等)

    • DISTINCT

    • GROUP BY

    • HAVING

      UNION 或者 UNION ALL




4. 视图的作用

  • 视图的所用?
  • 简单:视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
  • 安全:数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据。
  • 数据独立:视图可帮助用户屏蔽真实表结构变化带来的影响。




在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/190125.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DAO和增删改查通用方法-BasicDao

文章目录 一、BasicDao是什么&#xff1f;二、BasicDao分析三、BasicDao实现&#xff08;1&#xff09;BasicDao&#xff08;2&#xff09;ActorDao&#xff08;3&#xff09;TestDao 四、总结 一、BasicDao是什么&#xff1f; BasicDao:基础的数据对象&#xff0c;可以完成通用…

AD教程 (十八)导入常见报错解决办法(unkonw pin及绿色报错等)

AD教程 &#xff08;十八&#xff09;导入常见报错解决办法&#xff08;unkonw pin及绿色报错等&#xff09; 常见报错解决办法 绿色报错 可以先按TM&#xff0c;复位错位标识绿色报错原因一般是由于规则冲突的原因&#xff0c;和规则冲突就会报错 点击工具&#xff0c;设计…

RK3568驱动指南|第七篇 设备树-第67章 of操作函数实验:获取属性

瑞芯微RK3568芯片是一款定位中高端的通用型SOC&#xff0c;采用22nm制程工艺&#xff0c;搭载一颗四核Cortex-A55处理器和Mali G52 2EE 图形处理器。RK3568 支持4K 解码和 1080P 编码&#xff0c;支持SATA/PCIE/USB3.0 外围接口。RK3568内置独立NPU&#xff0c;可用于轻量级人工…

vmware workstation pro 17.5 安装 macos 13.5.2 虚拟机超详细图文教程

前言 本文很细&#xff0c;甚至有点墨迹&#xff0c;主要为了方便从来没用过 vmware 的新人&#xff0c;其实大部分步骤和正常安装虚拟机没有区别&#xff0c;详细贴图以方便大家对比细节 参考文章 感谢大佬们的无私分享 https://blog.csdn.net/qq_19731521/article/details…

Python每日一练@前言

Python每日一练前言 导读 人生苦短&#xff0c;我用Python 大家好&#xff0c;我是鹅不糊涂 欢迎大家来到Python每日一练 好处 加强编程能力: 每日一练可以帮助提升编程技能&#xff0c;通过解决各种编程问题和挑战&#xff0c;你能够不断锻炼自己的逻辑思维和解决问题的能力…

互联网医院牌照|智慧医疗离不开牌照办理

互联网医院牌照是由卫生健康行政部门颁布的&#xff0c;所有材料审核通过后&#xff0c;相关部门授予《医疗机构执业许可证》&#xff0c;取得牌照后才有开展互联网诊疗活动的资质&#xff0c;但开展线上问诊也需要向发证机关提出申请&#xff0c;下面小编就给大家讲解下互联网…

4.1指令系统-指令格式

现代计算机的结构 计算机的工作过程 指令的定义 指令&#xff08;又称机器指令&#xff09;&#xff1a; 是指示计算机执行某种操作的命令&#xff0c;是计算机运行的最小功能单位。 一台计算机的所有指令的集合构成改机指令系统&#xff0c;也称为指令集。 注意&#xff1…

4.6 Windows驱动开发:内核遍历进程VAD结构体

在上一篇文章《内核中实现Dump进程转储》中我们实现了ARK工具的转存功能&#xff0c;本篇文章继续以内存为出发点介绍VAD结构&#xff0c;该结构的全程是Virtual Address Descriptor即虚拟地址描述符&#xff0c;VAD是一个AVL自平衡二叉树&#xff0c;树的每一个节点代表一段虚…

AlphaControls控件TsDBCombobox出错:访问违规

日常使用AlphaControls控件TsDBCombobox&#xff0c;作为数据变化数据的控件。通常正常使用&#xff0c;一日 发现&#xff0c;出现以下错误&#xff1a; 控件访问违规的源代码&#xff0c;出错代码&#xff1a; function TacMainWnd.CallPrevWndProc(const Handle: hwnd; co…

LrC ACR :优化的 AI 天空蒙版

在 Lightroom Classic 和 Adobe Camera Raw 中创建基于 AI 技术的天空蒙版时&#xff0c;可能由于底层算法的原因&#xff0c;选中的天空蒙版在边缘处有晕开的现象&#xff08;又称为“出血” Bleed&#xff09;&#xff0c;从而导致天空蒙版不是很精准。 本文提供了一种特殊方…

无需公网IP,使用MCSM面板一键搭建我的世界Minecraft服务器联机游戏

文章目录 前言1.Mcsmanager安装2.创建Minecraft服务器3.本地测试联机4. 内网穿透4.1 安装cpolar内网穿透4.2 创建隧道映射内网端口 5.远程联机测试6. 配置固定远程联机端口地址6.1 保留一个固定TCP地址6.2 配置固定TCP地址 7. 使用固定公网地址远程联机 前言 MCSManager是一个…

Ghidra逆向工具配置 MacOS 的启动台显示(Python)

写在前面 通过 ghidra 工具, 但是只能用命令行启动, 不太舒服, 写个脚本生成 MacOS 的 app 格式并导入启动台. 不算复杂, 主要是解析包的一些元信息还有裁剪软件图标(通过 MacOS 自带的 API) 脚本 #!/opt/homebrew/bin/python3import os import re import subprocess as sp…