【MySQL 数据库】视图

在日常 MySQL 开发中,你是否经常遇到重复编写复杂多表查询需要控制数据访问权限想简化业务 SQL 逻辑的场景?

这时候,视图(View) 就是你的绝佳解决方案。

本文基于 MySQL 视图核心特性,从概念、基本使用、规则限制、实战案例全方位讲解,帮你彻底掌握视图,写出更简洁、安全、易维护的 SQL。


一、什么是 MySQL 视图?

官方定义 :视图是一个虚拟表 ,内容由查询定义。和真实表一样,视图包含带名称的列和行数据,但不物理存储数据,只存储查询语句本身。

核心特性

  1. 虚拟性 :不存数据,数据来自底层基表,查询时动态执行 SQL 生成结果集。
  2. 联动性:视图数据变化会影响基表;基表数据变化也会同步到视图。
  3. 封装性:把复杂查询(多表连接、筛选、排序)封装成简单 "表",复用极高。
  4. 安全性:可只暴露部分字段,隐藏敏感信息,控制数据访问范围。

一句话总结:视图 = 固化的 SELECT 查询 + 虚拟表外壳,查视图就像查普通表,背后自动跑复杂 SQL。


二、视图基本使用(增删改查全流程)

1. 创建视图(CREATE VIEW)

语法

sql

复制代码
CREATE VIEW 视图名 AS
SELECT 列1, 列2, ... FROM 基表 WHERE 条件;

经典案例 员工表 EMP + 部门表 DEPT,关联查询员工姓名和部门名称:

sql

复制代码
CREATE VIEW v_ename_dname AS
SELECT ename, dname
FROM EMP, DEPT
WHERE EMP.deptno = DEPT.deptno;

创建后,直接像表一样查询:

sql

复制代码
SELECT * FROM v_ename_dname ORDER BY dname;

查询结果示例:

表格

ename dname
CLARK ACCOUNTING
KING ACCOUNTING
SMITH RESEARCH
ALLEN SALES

2. 查询视图

和查询普通表完全一样 ,支持 WHEREORDER BYLIMIT 等:

sql

复制代码
-- 查询销售部员工
SELECT * FROM v_ename_dname WHERE dname = 'SALES';

3. 更新视图(联动基表)

视图是虚拟表 ,更新视图会直接修改基表数据

示例:把视图中姓名 CLARK 改为 TEST

sql

复制代码
UPDATE v_ename_dname SET ename = 'TEST' WHERE ename = 'CLARK';

查询基表 EMP:

sql

复制代码
SELECT * FROM EMP WHERE ename = 'TEST';

会发现基表数据已同步修改。

同理,修改基表,视图也会自动更新

sql

复制代码
-- 修改基表 JAMES 的部门为 10
UPDATE EMP SET deptno = 10 WHERE ename = 'JAMES';

-- 查询视图,数据已同步变化
SELECT * FROM v_ename_dname WHERE ename = 'JAMES';

4. 删除视图(DROP VIEW)

删除视图不会影响基表数据,只删除视图定义:

sql

复制代码
DROP VIEW 视图名;

示例:

sql

复制代码
DROP VIEW v_ename_dname;

三、视图规则与限制(必看,避坑关键)

使用视图时,必须遵守以下规则,否则容易报错或出现性能问题:

  1. 命名唯一视图名不能与现有表名、其他视图名重复。

  2. 数量无上限,但注意性能 可创建任意多个视图,但复杂查询封装成视图,频繁查询可能有性能损耗。

  3. 无索引、无触发器、无默认值 视图不能创建索引,也不能绑定触发器、设置字段默认值。

  4. 依赖权限必须拥有基表的查询权限,才能创建和使用视图,可用于提升数据安全性。

  5. ORDER BY 会被外层覆盖 视图里写了 ORDER BY,外层查询又写 ORDER BY视图的排序失效,以外层为准。

  6. 可与表混用视图可以和真实表一起关联查询,语法无限制。


四、视图实战 OJ 案例(牛客真题)

题目:针对 actor 表创建视图 actor_name_view,只保留 first_namelast_name 字段,要求视图字段名显示为 first_name_vlast_name_v

实战OJ链接:针对actor表创建视图actor_name_view_牛客题霸_牛客网

解题 SQL

sql

复制代码
CREATE VIEW actor_name_view AS
SELECT first_name AS first_name_v, last_name AS last_name_v
FROM actor;

说明

  • AS 给视图列重命名,适配业务展示需求。
  • 视图只暴露指定字段,实现数据脱敏与安全控制。

五、视图使用场景与优势

1. 简化复杂 SQL

多表连接、子查询、聚合计算,封装成视图,下次直接 SELECT * FROM 视图,大幅减少重复代码。

2. 提升数据安全性

不给用户开放全表权限,只开放视图,隐藏密码、身份证等敏感字段。

3. 统一业务逻辑

多处使用相同查询逻辑,只需修改视图定义,所有调用处自动同步,避免多处修改出错。

4. 解耦业务与表结构

基表结构调整时,可通过视图保持对外接口不变,业务代码不用大面积修改。


六、总结

  1. 视图是虚拟表,不存数据,只存查询 SQL
  2. 视图与基表数据联动,改视图 = 改基表,改基表 = 改视图。
  3. 核心操作:CREATE VIEW 创建、SELECT 查询、UPDATE 更新、DROP VIEW 删除。
  4. 注意:无索引、命名唯一、排序会被外层覆盖。
  5. 价值:简化查询、保障安全、统一逻辑、提升可维护性。

学会视图,你的 MySQL 开发效率和代码质量会直接上一个台阶!

相关推荐
weixin_459753941 小时前
mysql如何批量重置数据库用户密码_MySQL批量修改密码Shell脚本
jvm·数据库·python
AC赳赳老秦1 小时前
OpenClaw与飞书多维表格联动:自动同步工作数据、生成统计图表,实现高效管理
java·数据库·python·信息可视化·飞书·deepseek·openclaw
黑贝是条狗1 小时前
注册表破解chrome,edge阻止浏览器连接本地websocket
前端·javascript·数据库
爱喝水的鱼丶1 小时前
SAP-ABAP:第二篇:实操避坑篇——ABAP Hello World程序创建、语法校验到调试运行全流程指南
运维·服务器·数据库·学习·sap·abap
m0_609160491 小时前
mysql如何避免大批量数据修改锁全表_使用分批提交技术
jvm·数据库·python
Languorous.1 小时前
MySQL 零基础安装教程(Windows11/10,图文分步,新手零失败)
数据库·mysql·adb
wang3zc1 小时前
golang如何实现工作流引擎_golang工作流引擎实现要点
jvm·数据库·python
m0_591364731 小时前
如何在 Django ListView 中正确过滤当前用户的照片数据
jvm·数据库·python
ㄟ留恋さ寂寞1 小时前
Vue.js核心基础之响应式系统与虚拟DOM渲染关联机制
jvm·数据库·python