MySQL视图
一、视图的本质与分类
1. 定义
-
虚拟表:视图不存储数据,本质是保存的查询语句(
SELECT
),每次访问视图时动态执行查询并返回结果。 -
逻辑抽象:基于一个或多个基表(或视图)创建,提供数据展示的定制化逻辑层。
2. 分类
类型 | 特征 | 示例 |
---|---|---|
简单视图 | 基于单表,不包含聚合函数、分组、去重等操作,可直接更新数据 | CREATE VIEW v_employees AS SELECT id, name FROM employees; |
复杂视图 | 涉及多表连接、聚合函数(SUM 、COUNT )、GROUP BY ,通常不可更新 | CREATE VIEW v_sales_summary AS SELECT product_id, SUM(amount) FROM sales GROUP BY product_id; |
二、视图操作全流程
1. 创建视图
-
基础语法:
CREATE VIEW view_name [(column_list)] AS SELECT_statement [WITH [CASCADED | LOCAL] CHECK OPTION]; -- 可选:约束更新条件
-
示例:
-- 指定列名 CREATE VIEW v_student_scores (s_id, s_name, course, score) AS SELECT s.student_id, s.name, c.course_name, sc.score FROM students s JOIN scores sc ON s.student_id = sc.student_id JOIN courses c ON sc.course_id = c.course_id;-- 动态列名(默认使用SELECT列别名) CREATE VIEW v_dept_avg_salary AS SELECT dept_id, AVG(salary) AS avg_salary FROM employees GROUP BY dept_id;
2. 查看视图
-
查看元数据:
SHOW TABLES; -- 列出所有表(含视图) SHOW CREATE VIEW v_student_scores; -- 显示视图定义 DESC v_student_scores; -- 查看视图结构
-
查询视图数据:
SELECT * FROM v_student_scores WHERE score > 80;
3. 更新视图
-
直接更新条件(需满足以下全部):
-
视图基于单表。
-
不包含聚合函数、
DISTINCT
、GROUP BY
、HAVING
。 -
未使用子查询或某些联合查询(如
UNION
)。 -
包含基表所有非空且无默认值的列(若插入数据)。
-
-
示例:
-- 更新视图(影响基表) UPDATE v_simple_emp SET salary = 5000 WHERE id = 101;-- 插入数据(需满足基表约束) INSERT INTO v_simple_emp (id, name) VALUES (105, 'John');
4. 删除视图
DROP VIEW IF EXISTS v_old_sales_data; -- 安全删除
三、视图的核心优势
1. 简化复杂查询
-
封装多表连接、子查询:
-- 复杂查询转换为视图 CREATE VIEW v_customer_orders AS SELECT c.name, o.order_date, SUM(od.quantity * p.price) AS total FROM customers c JOIN orders o ON c.id = o.customer_id JOIN order_details od ON o.id = od.order_id JOIN products p ON od.product_id = p.id GROUP BY c.id, o.id;-- 后续查询只需: SELECT * FROM v_customer_orders WHERE total > 1000;
2. 数据安全与权限控制
-
列级权限:仅暴露必要字段。
CREATE VIEW v_emp_public AS SELECT id, name, department FROM employees; -- 隐藏薪资字段
-
行级过滤:动态限制数据范围。
CREATE VIEW v_hr_employees AS SELECT * FROM employees WHERE department = 'HR';
3. 逻辑数据独立性
-
基表结构变更时,通过调整视图定义保持接口稳定:
-- 原视图 CREATE VIEW v_old AS SELECT id, name FROM users;-- 基表新增列后更新视图 CREATE OR REPLACE VIEW v_old AS SELECT id, name, email FROM users;
4. 统一业务逻辑
-
复用复杂计算或格式化规则:
CREATE VIEW v_sales_report AS SELECT product_id,DATE_FORMAT(sale_date, '%Y-%m') AS sale_month,COUNT(*) AS total_sales,CONCAT('$', FORMAT(SUM(amount), 2) AS total_amount FROM sales GROUP BY product_id, sale_month;
四、视图的局限性及应对策略
1. 性能问题
-
动态计算开销:每次查询视图需重新执行
SELECT
语句。 -
优化方案:
-
对基表添加合适索引。
-
使用物化视图(MySQL需通过中间表模拟)。
-
2. 更新限制
-
不可更新场景:
-
包含聚合函数、
DISTINCT
、GROUP BY
。 -
使用
UNION
、子查询或JOIN
(部分情况)。
-
-
替代方案:
-
通过存储过程封装更新逻辑。
-
直接操作基表。
-
3. 维护成本
-
级联影响:修改基表结构可能导致视图失效。
-
应对措施:
-
使用
SHOW WARNINGS
检查视图状态。 -
定期执行
CHECK TABLE
验证视图有效性。
-
五、高级应用与最佳实践
1. 视图嵌套
-
基于视图创建新视图,构建多层抽象:
CREATE VIEW v_monthly_sales AS SELECT sale_month, SUM(total_sales) AS monthly_total FROM v_sales_report GROUP BY sale_month;
2. 安全增强:WITH CHECK OPTION
-
强制更新/插入满足视图条件的数据:
CREATE VIEW v_active_users AS SELECT * FROM users WHERE status = 'active' WITH CHECK OPTION; -- 禁止插入status非active的数据
3. 动态视图(通过函数或变量)
-
结合用户变量实现动态过滤:
SET @user_role = 'manager'; CREATE VIEW v_role_based AS SELECT * FROM employees WHERE role = @user_role;
六、视图与临时表对比
特性 | 视图 | 临时表 |
---|---|---|
存储方式 | 仅存储查询逻辑,无物理存储 | 物理存储在内存或磁盘 |
生命周期 | 永久或会话级(TEMPORARY VIEW ) | 会话结束自动删除 |
更新支持 | 部分可更新 | 完全可更新 |
性能 | 依赖基表索引 | 可单独索引 |
适用场景 | 逻辑封装、权限控制 | 中间结果暂存、复杂计算分步 |
七、总结:视图的最佳实践
-
设计原则:
优先用于简化查询而非性能优化,避免过度嵌套(建议不超过3层)。 -
安全规范:
通过视图实现最小权限原则,使用WITH CHECK OPTION
约束数据完整性。 -
维护策略:
文档记录视图依赖关系,定期审查并清理无用视图。
。
相关文章:
MySQL视图
一、视图的本质与分类 1. 定义 虚拟表:视图不存储数据,本质是保存的查询语句(SELECT),每次访问视图时动态执行查询并返回结果。 逻辑抽象:基于一个或多个基表(或视图)创建…...
程序化广告行业(69/89):电商素材制作与展示策略解析
程序化广告行业(69/89):电商素材制作与展示策略解析 在如今数字化营销的浪潮中,程序化广告成为众多企业精准触达目标客户的有力武器。作为一名在广告技术领域摸爬滚打多年的从业者,深知学习是不断进步的阶梯ÿ…...
【PCB工艺】发光二极管的原理
你真的知道发光二极管为什么会发光吗? 而为什么另一部分二极管不会发光呢? 这篇文章解释元器件发光二极管(LED)的底层原理。 发光二极管(LED, Light Emitting Diode) 是一种能够将电能转换为光能的半导体…...
探秘 DeepSeek:开源生态如何推动 AI 技术普惠?
探秘 DeepSeek:开源生态如何推动 AI 技术普惠? 引言 在人工智能(AI)领域,技术的快速发展和广泛应用正在深刻改变我们的生活。然而,AI 的发展往往伴随着资源和技术的集中化问题,大型科技公司凭借其雄厚的资金和人才优势占据了主导地位,而中小企业、研究机构和个人开发…...
远程主机可能不符合glibc和libstdc++ VS Code服务器的先决条件
这是因为我最近更新了vscode, 服务器中有个GLIBC库,VSCode>1.86.0版本对 低于v2.28.0版本的GLIBC不再满足需求。 解决办法 回退到之前能够连接服务器的版本。我之前用的是January 2025 (version 1.97) vscode旧版本下载地址...
JVM性能调优:参数配置×内存诊断×GC调优实战
🚀前言 “你的Java应用是否还在经历莫名卡顿?半夜被OOM报警惊醒?GC日志像天书看不懂? 本文将用20个真实案例50个关键参数,带你掌握: 参数调优:如何用-XX:UseG1GC让GC暂停从秒级降到毫秒级&…...
pg_waldump 使用方法和输出验证
目录 pg_waldump 使用方法和输出验证一、pg_waldump 基础用法二、验证输出文件正确性三、关键参数 -p 的作用四、验证示例五、注意事项 pg_waldump 使用方法和输出验证 一、pg_waldump 基础用法 命令格式 pg_waldump [选项] [WAL文件路径]-p, --pgdataDIR:指定 Pos…...
Android 定制飞行模式和通话中设置菜单置灰
业务背景 定制需求实现 目标:通话中禁用移动网络设置中的网络模式和APN入口。 Google原生行为分析 在原生Android中: 飞行模式: 无法在通话中开启:系统会自动阻止,因飞行模式会断开通话所需的射频。APN/网络模式修改…...
C# System.Text.Json 中 ReferenceHandling 使用详解
总目录 一、什么是 ReferenceHandling? 1. 概述 ReferenceHandling 是 System.Text.Json 中用于处理对象引用(循环引用或重复引用)的选项。它允许开发者在序列化和反序列化时控制如何处理对象之间的引用关系。 默认情况下,Syst…...
【开发经验】调试OpenBMC Redfish EventService功能
EventService功能是Redfish规范中定义的一种事件日志的发送方式。用户可以设置订阅者信息(通常是一个web服务器),当产生事件日志时,OpenBMC可以根据用户设置的订阅者信息与对日志的筛选设置,将事件日志发送到订阅者。 相比于传统的SNMPTrap日…...
【AI工具】FastGPT:开启高效智能问答新征程
前言 在人工智能飞速发展的当下,各类 AI 工具如雨后春笋般涌现。FastGPT 作为一款基于大语言模型(LLM)的知识图谱问答系统,凭借其强大的数据处理和模型调校能力,为用户带来了便捷的使用体验。今天,就让我们…...
4.8学习总结 贪心算法+Stream流
贪心算法: 找到局部最优->从而推导全局最优。 Java练习: 获取随机验证码: import java.util.*; import java.util.function.BiConsumer; public class test {public static void main(String[] args) {System.out.println(createCode(…...
入选ICLR‘25 Spotlight!深度强化学习(DRL)迎来新突破!
近年来,深度强化学习相关的成果在顶会顶刊上接受度普遍较高,经常上榜ICLR、Nature、Science等。比如ICLR 2025上的一篇Spotlight,由清华团队提出,介绍了一种SmODE网路,让深度强化学习的控制更加丝滑! 另外…...
【学习笔记】HTTP和HTTPS的核心区别及工作原理
一、基础概念 HTTP(超文本传输协议):明文传输数据,默认端口80,容易被窃听或篡改。 HTTPS(HTTP SSL/TLS):通过加密传输数据,默认端口443,保障安全性。 二、…...
gbase8s之数据字典导出脚本(完美)
有时我们需要将表结构转换成数据库设计文档(WORD或者其他格式),这时需要使用脚本将表结构导出,转换成可用格式。 该脚本适用于GBase 8s小版本号在3.0之后的版本(含有syscolumnsext、syscomments以及syscolcomments表&a…...
java整合socket通信全流程
前言 大家好,由于工作上业务的需要,在java项目中引入了socket通信,特此记录一下,用以备份,本文章中的socket通信实现了,服务端与客户端的双向通讯,以及二者之间的心跳通信,服务端重启之后,客户端的自动重连功能。 原理 Socket通信是计算机网络中常用的一种通信机制…...
【scikit-learn基础】--『预处理』之 正则化
数据的预处理是数据分析,或者机器学习训练前的重要步骤。 通过数据预处理,可以 提高数据质量,处理数据的缺失值、异常值和重复值等问题,增加数据的准确性和可靠性整合不同数据,数据的来源和结构可能多种多样ÿ…...
WHAT - React 使用 Hook 分离计算逻辑与渲染逻辑
目录 原始代码如何优化1. 函数式简洁风格2. hook 封装(重点)3. 性能优化 原始代码 const GoodList ({ goods }) > {if (goods.length 0) {return <>暂无数据</>;}let totalCount 0;let totalPrice 0;goods.forEach((good) > {tot…...
AI比人脑更强,因为被植入思维模型【49】冰山理论思维模型
giszz的理解:冰山一角,冰山理论并不深奥,就是这个意思。对我启发比较大的,就是人的一个行为,背后可能藏着行为、应对方式、感受、观点、期待、渴望、自我七个层次。更有一个扩展,就是每个人的自我ÿ…...
【Linux】Git的简单使用
📝前言: 这篇文章我们来讲讲版本控制器Git,主要掌握一些简单的本地仓库与远端仓库之间的文件传输操作。 🎬个人简介:努力学习ing 📋个人专栏:Linux 🎀CSDN主页 愚润求学 ἰ…...
【WebRTC】开源项目Webrtc-streamer介绍
WebRTC-Streamer 这是一个用于通过简单的信令机制(参见 api)流式传输 WebRTC 媒体源的实验项目,支持以下媒体源: 捕获设备 屏幕捕获 mkv 文件 RMTP/RTSP 源 同时该项目也兼容 WHEP 接口。 注意 * 在线演示已停止,…...
Bigemap pro制作行政区域图
Bigemap pro制作行政区域图 第一步:打开bigemap pro软件,右上角加载更多矢量到地图上,加载出来需要的矢量数据,以北京市为例,如图所示: 第二步:在我的矢量图层,点击右键,…...
Kotlin 和 spring-cloud-function 兼容问题
错误: [ERROR] Failed to execute goal org.jetbrains.kotlin:kotlin-maven-plugin:1.9.25:compile (compile) on project springdoc-openapi-starter-common: Compilation failure [ERROR] /opt/repository/org/springframework/cloud/spring-cloud-function-conte…...
OpenVINO是什么
OpenVINO(Open Visual Inference and Neural Network Optimization)是由英特尔(Intel)开发的一个开源工具套件,用于优化和加速深度学习模型的推理过程,特别是在计算机视觉、自然语言处理和生成式 AI 等领域…...
【学Rust写CAD】38 over_in 函数(alpha256补充方法)
源码 #[inline] // 内联优化标记 pub fn over_in(self, src: Argb, dst: Argb) -> Argb {// 计算目标alpha因子 self * src的alpha通道let dst_alpha self * src.alpha_t();// 预乘源和目标的颜色分量let src_rb src.rb() * self.0; // 源的红蓝分量乘以alpha因子let …...
球类(继承和多态)
父类Ball,设置为抽象类,调用get和set方法创建对象,将子类重写的功能函数抽象化。 // 抽象球类 abstract class Ball {private String name;private double radius; // 半径private double weight; // 重量private double price; // 价格// 构…...
苍穹外卖(1)-部分环境配置(git、数据库)
首先配置git 创建好本地仓库之后 把项目弄到远程仓库里去 先进行提交 ,后进行推送 ,然后gitee创建一个仓库 把这个url复制好 推送后会出来一个 点击推送,会让你输入gitee账号密码,输入自己的账号密码,就可以连接远程仓…...
避免误用strncmp与memcmp,strcpy与memcpy
(Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu) 注:使用说明部分参考豆包ai 1. 字符串与二进制流认知 许多时候,我们作为软件研发人员,会觉得 一段内存就是一串字符串;字符串就是一段内存; 概念上ÿ…...
华为欧拉系统安装docker
华为欧拉系统安装docker cat /etc/openEuler-release sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo vi /etc/yum.repos.d/docker-ce.repo dnf makecache dnf install https://download.docker.com/linux/centos…...
windows11怎么把notepad++添加到鼠标右键菜单?
在Windows 11中将Notepad添加到鼠标右键菜单,可通过以下两种方法实现: 方法一:手动修改注册表(推荐) 打开注册表编辑器 按下 Win R,输入 regedit 并回车 1 2 3 。 定位注册表路径…...
HTML5笔记: 什么是HTML
HTML的全称为超文本标记语言,是一种标记语言。它包括一系列标签,通过这些标签可以将网络上的文档格式统一,使分散的Internet资源连接为一个逻辑整体。HTML文本是由HTML命令组成的描述性文本,HTML命令可以说明文字,图形…...
【WRF理论第十五期】WPS中输入geogrid二进制格式
WPS中输入geogrid二进制格式 基本概念:Geogrid二进制格式支持的数据类型 geotiff→tiff的规则说明类型1:主导类别字段(Dominant Category Field)类型2:连续字段(Continuous Field)类型3…...
《UNIX网络编程卷1:套接字联网API》第8章:基本UDP套接字编程深度解析
《UNIX网络编程卷1:套接字联网API》第8章:基本UDP套接字编程深度解析(8000字图文实战) 一、UDP协议核心特性与编程模型 1.1 UDP协议设计哲学 UDP(User Datagram Protocol) 是面向无连接的传输层协议&…...
【WPF】IOC控制反转的应用:弹窗但不互相调用ViewModel
全称:Inversion of Control,控制反转 场景:A页面需要调用B/C页面等,防止直接在VM中新建别的页面实例,使用IOC设计架构; 创建Service,在Service中实现页面的实例创建和定义页面输入输出参数。 在…...
解决制作CI流水线时的no host异常报错
方法介绍 使用 HostAliases 向 Pod /etc/hosts 文件添加条目 当dns配置以及其他选项不合理时,可以通过向pod的/etc/hosts添加条目,可以在pod级别覆盖对主机名的解析,可以通过pod spec的pod aliases来自定义添加条目。 默认的hosts文件内容 …...
(AI+医疗)2025最应该学习是--医学AI大模型LLM应用与开发
(AI医疗)2025最应该学习是–医学AI大模型LLM应用与开发!! AI技术正在为医学领域带来的现实变革。而实现这一切的核心,正是自然语言大模型(LLM)的应用与开发。 为什么医学AI是未来的风口? AI正在重塑医疗行业。从智能问诊到辅助…...
MCP+Deepseck王炸组合 | 附实战操作及其MCPserver | 可替代Manus,实现AGI
MCP介绍 MCP 是一个开放协议,它为应用程序向 LLM 提供上下文的方式进行了标准化。你可以将 MCP 想象成 AI 应用程序的 USB-C 接口。就像 USB-C 为设备连接各种外设和配件提供了标准化的方式一样,MCP 为 AI 模型连接各种数据源和工具提供了标准化的接口。…...
STM32学习之ARM内核自带的中断
📢:如果你也对机器人、人工智能感兴趣,看来我们志同道合✨ 📢:不妨浏览一下我的博客主页【https://blog.csdn.net/weixin_51244852】 📢:文章若有幸对你有帮助,可点赞 👍…...
Java 设计模式:工厂模式详解
Java 设计模式:工厂模式详解 工厂模式(Factory Pattern)是一种创建型设计模式,它通过将对象的创建过程封装到工厂类中,避免了直接使用 new 关键字创建对象,从而提高了代码的灵活性和可维护性。本文将介绍工…...
python内置标准模块--OS
内置标准模块–OS 在 Python 中,os 是一个内置标准模块,全称是 Operating System(操作系统)。它的核心作用是与当前操作系统交互,提供对文件系统、进程管理、环境变量等操作系统功能的访问接口 1. os 模块的核心功…...
echart实现动态折线图(vue3+ts)
最近接到个任务,需要用vue3实现动态折线图。之前没有用过,所以一路坎坷,现在记录一下,以后也好回忆一下。 之前不清楚echart的绘制方式,以为是在第一秒的基础上绘制第二秒,后面实验过后,发现并…...
Web3(阶段一:入门)——椭圆曲线
一、快速概览 ECC 是一种基于有限域上椭圆曲线代数结构的公钥加密系统。它提供与 RSA 相当的安全性,但密钥长度要短得多,从而实现更快的计算速度和更低的资源使用率。ECC 广泛应用于各种应用,包括安全通信、数字签名和加密货币。 二、什…...
vue总结
1.vue是什么。 vue是javascript和html结合后的,实现了html的模块开发,并且样式和js互不影响。组件内的javascript逻辑只在组件内有效,当然父类可通过某些方法调用,但是彼此间没有影响。各个组件的样式,通过scope防止了…...
LCR 131. 砍竹子 I
文章目录 题意思路代码 题意 题目链接 思路 代码 class Solution { public:int cuttingBamboo(int bamboo_len) {if (bamboo_len 2)return 1;if (bamboo_len 3)return 2;if (bamboo_len 4)return 4;int x bamboo_len / 3;int ans pow(3, x);int y bamboo_len % 3;if …...
游戏引擎学习第210天
回顾并为今天的工作做准备 今天我们,进行一些编码工作。这部分的编码内容对那些对代码架构感兴趣的人非常有帮助,我认为今天的编码内容会很有教育意义,尤其是在展示一些代码转化的过程中,希望大家能够从中获得一些启发。 接下来…...
40--华为IPSec VPN实战指南:构建企业级加密通道
🛡️ 华为IPSec VPN实战指南:构建企业级加密通道 “当数据开始穿盔甲,黑客只能望’密’兴叹” —— 本文将手把手教你用华为设备搭建军用级加密隧道,从零开始构建网络长城! 文章目录 🛡️ 华为IPSec VPN实战…...
go游戏后端开发28:胡牌算法实现
红中麻将胡牌逻辑开发文档 一、字牌与封牌的字典表构建 在开发红中麻将胡牌逻辑时,首先需要构建非字牌和封牌的字典表。在构建双层表时,需进行判断:若牌为风牌且索引 i 大于 6,则不进行处理。这是因为风牌包含东南西北中&#x…...
CNN注意力机制的进化史:深度解析10种注意力模块如何重塑卷积神经网络
🌟 引言:注意力为何改变CNN的命运? 就像人类视觉会优先聚焦于重要信息,深度学习模型也需要"学会看重点"。从2018年SENet首提通道注意力,到2024年SSCA探索空间-通道协同效应,注意力机制正成为CNN…...
字符串与字符数组的对比
在 C 语言中,字符串 和 字符数组 密切相关,但又有重要区别。以下是它们的对比: 1. 基本定义 字符数组 (char array) 是一个固定大小的数组,元素类型是 char。可以存储字符序列,但不一定以 \0 结尾。例如:…...
mapbox进阶,模仿百度,实现不同楼栋室内楼层切换
👨⚕️ 主页: gis分享者 👨⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨⚕️ 收录于专栏:mapbox 从入门到精通 文章目录 一、🍀前言1.1 ☘️mapboxgl.Map 地图对象1.2 ☘️mapboxgl.Map style属性1.3 ☘️fill-extrusion 三维填充(白膜)图层样…...