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

news2024/10/5 21:17:25

在这里插入图片描述

个人简介: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.coloradmin.cn/o/1222765.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

U盘如何自定义图标?

1、准备一张图片&#xff0c;转换为.ico格式&#xff0c;转换格式的工具推荐一个ToYcon 转换好后放到拷贝到u盘里面。 2、在u盘里面新建一个文本文档&#xff0c;在文档里面写入以下内容&#xff0c;注意&#xff0c;这里的test为图片的名称。 根据自己图片名称做一下修改。 […

CAD Exchanger SDK 3.23.0 的亮点

代号“CAD Exchanger MTK”的新兴产品首次亮相&#xff0c;支持新版本的流行格式&#xff0c;重新设计的 BIM 模型结构以及 3.23.0 中的 SDK 文档修订 阅读最新版本编写的 Autodesk Inventor 和 NX 文件&#xff0c;享受更严格的 BIM 模型结构&#xff0c;轻松浏览 SDK 文档&am…

三次握手和四次握手到底有啥区别?

1. 三次握手 TCP 协议中&#xff0c;在发送数据的准备阶段&#xff0c;客户端与服务器之间的三次交互&#xff0c;以保 证连接的可靠。 • 第一次握手&#xff0c;客户端向服务器端发起 TCP 连接的请求• 第二次握手&#xff0c;服务器端发送针对客户端 TCP 连接请求的确认•…

FISCO BCOS 3.0【01】搭建第一个区块链网络

官方技术文档&#xff1a;https://fisco-bcos-doc.readthedocs.io/zh-cn/latest/index.html 我们在官方技术文档的基础上&#xff0c;进行&#xff0c;对文档中一些不清楚的地方进行修正 搭建Air版本FISCO BCOS联盟链 本节以搭建单群组FISCO BCOS链为例操作&#xff0c;使用开…

NPDP 02组合管理

NPDP 产品经理认证知识体系指南解读&#xff0c;02组合管理 第二章 组合管理 公司战略或经营战略以及创新战略&#xff0c;为竞争性创新投资之间的权衡决策提供了整体方向和框架。在发展和持续性维护一个组织的产品组合时&#xff0c;总要面对一系列彼此竞争资源和投资的项目。…

Spring Cloud学习(九)【Elasticsearch 分布式搜索引擎01】

文章目录 初识 elasticsearch了解 ES倒排索引ES 的一些概念安装es、kibana安装elasticsearch部署kibana 分词器安装IK分词器ik分词器-拓展词库 索引库操作mapping 映射属性索引库的 CRUD 文档操作添加文档查看、删除文档修改文档Dynamic Mapping RestClient 操作索引库什么是Re…

Docker之DockerFile解析

DockerFile解析 是什么 Dockerfile是用来构建Docker镜像的文本文件&#xff0c;是由一条条构建镜像所需的指令和参数构成的脚本。 概述 官网 https://docs.docker.com/engine/reference/builder/ 构建三步骤 编写Dockerfile文件 docker build命令构建镜像 docker run依镜像运…

轻地图+数据闭环加速落地,觉非科技获多家头部车企定点

‍作者 |张祥威 编辑 |德新 智能驾驶日益普及&#xff0c;「轻地图」和「数据闭环」成为各家能力比拼的关键&#xff0c;车企对此的需求也逐渐迫切。 11月16日&#xff0c;觉非科技宣布已与多家头部主机厂达成量产定点合作&#xff0c;围绕轻地图与数据闭环服务&#xff0c;支…

人工智能Keras的第一个图像分类器(CNN卷积神经网络的图片识别)

CNN卷积神经网络是人工智能的开端,CNN卷积神经网络让计算机能够认识图片,文字,甚至音频与视频。CNN卷积神经网络的基础知识,可以参考:CNN卷积神经网络 LetNet体系结构是卷积神经网络的“第一个图像分类器”。最初设计用于对手写数字进行分类,上期文章我们分享了如何使用k…

.Net6 部署到IIS示例

基于FastEndpoints.Net6 框架部署到IIS 环境下载与安装IIS启用与配置访问网站 环境下载与安装 首先下载环境安装程序&#xff0c;如下图所示,根据系统位数选择x86或者x64进行下载安装,网址&#xff1a;Download .NET 6.0。 IIS启用与配置 启用IIS服务 打开控制面板&#xff…

深度学习基础知识——从人工神经网络开始

一、介绍 您知道第一个神经网络是在 20 世纪 50 年代初发现的吗&#xff1f; 深度学习 (DL) 和神经网络 (NN) 目前正在推动本世纪一些最巧妙的发明。他们从数据和环境中学习的令人难以置信的能力使他们成为机器学习科学家的首选。 深度学习和神经网络是自动驾驶汽车、图像识别软…

AI先行者第三辑:石油专家正在加速“吸入”AI养分

AI对于石油行业而言&#xff0c;绝不是一个非此即彼、非黑即白、有用或者无用的简单命题&#xff0c;而是一个如何不断深入去提升效率&#xff0c;逐步证明自己价值的过程。 本篇作者安鹏&#xff0c;中国海洋石油集团有限公司信息技术中心 技术中台工程师&#xff1b;AICA首席…

22款奔驰S450L升级钢琴内饰板 完美的融合进去

钢琴拉丝桃木面板装车让人眼前一亮&#xff0c;内饰的豪华度和高级感立马提升一个等级&#xff0c;带条纹的亮面烤漆&#xff0c;温润高端。 为什么升级更换桃木饰板&#xff1f;因为升级桃木饰板可以更换掉一些镀铬银色的装饰件&#xff0c;这样就可以让整车的豪华感大大的提升…

qt library创建和使用

1、创建library 2、修改library中的代码 3、把library进行编译&#xff0c;编译后会生成相关文件 4、把编译后的文件拷贝到主程序目录下面。 5、并把library中的testlib头文件拷贝到主程序&#xff0c;并在pro文件加入&#xff08;这里在后面使用library中函数有关&#xff0…

基于LeNet实现手写体数字识别实验

目录 1 数据 1.1 数据预处理 2 模型构建 2.1 自定义算子实现 2.2 Pytorch框架实现 2.3 测试两个网络的运算速度 2.4 两个网络加载同样的权重&#xff0c;两个网络的输出结果是否一致&#xff1f; 2.5 计算模型的参数量和计算量。 3 模型训练 4 模型评价 5 模型预测 总结…

专攻数学的Prompt:使GPT-3解数学题准确率升至92.5%

专攻数学的Prompt&#xff1a;使GPT-3解数学题准确率升至92.5% 写在最前面示例&#xff08;试过了&#xff0c;难点的和普通输出差不多&#xff1b;只能说&#xff0c;比简单的题目输出内容更丰富一些&#xff09;MathPrompter解题示例 机理MathPrompter是怎么工作的&#xff0…

秋招算法高频算法笔试题

自己在秋招过程中遇到的算法笔试题&#xff0c;包含中大厂&#xff0c;都附解析&#xff01; 汽水瓶 如果汽水瓶数目为1或者0&#xff0c;那么一瓶都喝不到 如果汽水瓶数目为2或者3&#xff0c;那么只能喝到一瓶 如果为2&#xff0c;喝到一瓶后手里一个瓶子都没有了&#xff…

Flume学习笔记(3)—— Flume 自定义组件

前置知识&#xff1a; Flume学习笔记&#xff08;1&#xff09;—— Flume入门-CSDN博客 Flume学习笔记&#xff08;2&#xff09;—— Flume进阶-CSDN博客 Flume 自定义组件 自定义 Interceptor 需求分析&#xff1a;使用 Flume 采集服务器本地日志&#xff0c;需要按照日志…

for,while,do-while,死循环,嵌套循环,跳转关键字,随机数

1.for循环 public class ForDemo1 {public static void main(String[] args) {for (int i 0; i < 5; i) {System.out.println("HelloWorld");}System.out.println("--------------------------------------------");for (int i 1; i <10 ; i) {Sy…

SELF-RAG: 让LLM集检索,生成跟评判等多种能力于一身

SELF-RAG: 让LLM集检索&#xff0c;生成跟评判等多种能力于一身 提纲 1 简介 2 SELF-RAG 3 实验结论 4 讨论 参考文献 1 简介 尽管基础能力出众&#xff0c;但是大模型只能依赖于被压缩到模型参数中的知识&#xff0c;所以经常会生成不符合事实的回复。针对这种事实性错…