【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 开发效率和代码质量会直接上一个台阶!

相关推荐
北顾笙9803 分钟前
MYSQL-day03
数据库·sql·mysql
MXsoft6184 分钟前
**混合云统一监控实践:私有云+公有云的一体化运维方案**
运维·网络·数据库
瀚高PG实验室26 分钟前
java中间件无法连接数据库
java·数据库·中间件·瀚高数据库
ULIi096kr28 分钟前
MySQL大表优化终极方案:单表数据量上限、卡顿解决、分表分库实战教程
数据库·mysql
霖霖总总29 分钟前
[MongoDB小技巧07]MongoDB 深度解析:find中投影与排序的底层机制与性能调优实战
数据库·mongodb
TechWayfarer31 分钟前
云服务器地域怎么选:用离线IP数据库识别用户来源并优化部署
服务器·数据库·python·tcp/ip·数据分析
deviant-ART36 分钟前
MySQL里的三个concat函数
数据库·mysql
H_老邪1 小时前
1044 - Access denied for user ‘root‘@‘%‘ to database ‘nacos‘
数据库·mysql
数智化精益手记局1 小时前
拆解复杂项目管理流程:用项目管理流程解决跨部门协作低效难题
大数据·运维·数据库·人工智能·产品运营
xhtdj1 小时前
Uber 如何通过批处理实现单账户每秒30+次更新
大数据·数据库·人工智能·安全·动态规划