【MySQL】视图

一、基本概念

1、怎么理解视图

  • 视图是一个或多个数据表中的数据的逻辑显示,它是一个虚拟表,视图本身并不存储数据
  • 视图建立在已有表的基础上,它所依赖的表称为基表
  • 视图的创建和删除只影响视图本身,不影响基表,但是视图中数据增删改操作,会影响到基表中的数据
  • 向视图提供数据内容的语句为select语句,可以将视图理解为将某个select语句的查询结果存储起来了,并且我们还能通过对视图进行增删改操作来影响基表中的数据
  • 在大型项目或者数据比较复杂的情况下,使用视图可以把我们经常查询的字段存储到虚拟表中,大大提高了查询效率

2、为什么使用视图

  • 视图一方面可以帮我们使用表的一部分,而不是整个表
  • 另外我们可以针对不同级别的用户制定不同的查询视图。比如员工信息表中,某些级别比较低的员工,就看不到薪资和员工评级等敏感信息,这个时候就需要使用视图来完成这个操作了

3、视图的优点与缺点

  • 优点:
    • 简化操作:某些经常使用的查询操作可以定义为视图,业务只需要对视图进行操作即可
    • 减少数据冗余:视图本身并不存储数据,它是一个虚拟表,不占用存储数据的资源
    • 数据安全:可以让不同权限的用户看见不同的结果集
    • 能够分解复杂的逻辑:将复杂的问题进行拆解,变成一个个视图,然后在这些视图的基础上进行整合
  • 缺点:
    • 视图维护比较麻烦
    • 如果是嵌套视图,可读性比较差

二、视图的创建与查看

1、如何创建视图

sql 复制代码
CREATE VIEW 视图名称
AS
SELECT查询语句;

1)单表查询如何创建视图

情况一:视图中的字段与基表的字段有对应关系,假设我们要从员工表中查询某些字段作为视图

sql 复制代码
# 查询语句中的字段别名,会作为视图中的字段进行展示
CREATE VIEW vu_emp
AS
SELECT employee_id emp_id,last_name lname,salary
FROM t_employee;

# 小括号内的字段个数与SELECT中字段个数相同,小括号内的别名作为视图展示字段
CREATE VIEW vu_emp2(emp_id,lname,salary)
AS
SELECT employee_id,last_name,salary
FROM t_employee
WHERE salary > 8000;

情况二:视图中的字段在基表中没有对应字段,比如要将某个字段的平均值作为视图的字段

sql 复制代码
CREATE VIEW vu_emp3
AS
SELECT dept_id,AVG(salary) avg_salary
FROM t_employee
WHERE department_id IS NOT NULL
GROUP BY dept_id;

2)多表查询如何创建视图

sql 复制代码
CREATE VIEW vu_emp_dept
AS
SELECT e.emp_id,e.dept_id,d.dept_name
FROM t_employee e JOIN t_dept d
ON e.dept_id = d.dept_id;

3)使用视图对数据进行格式化

假设我们要查询员工表中的员工名称,并且在后面追加他的部门id

得到员工名称(部门id)这种形式的数据

sql 复制代码
CREATE VIEW vu_emp_dept_info
AS
SELECT CONCAT(last_name,'(',emp_id,')') emp_dep_info
FROM
t_dept;

4)基于视图创建视图

sql 复制代码
CREATE VIEW vu_dept_info
AS
SELECT dept_id,dept_name
FROM vu_emp_dept;

基于多个视图进行多表查询也是和上面表的多表查询也是一样的思路,都是使用JOIN关键字

2、查看视图

sql 复制代码
# 查看数据库中有多少表和视图
SHOW TABLES;

#查看视图的结构
DESC 视图名称;

#查看视图的详细信息
SHOW CREATE VIEW 视图名称;

3、更新与删除视图数据

  • 更新或者删除视图中的某部分数据,会同步影响基表中展示的数据。同理,更新或者删除基表中的部分数据,也会同步影响相关视图中展示的数据
  • 假设视图中的字段在基表中不存在,例如视图中某个字段是对基表中某个字段使用聚合函数得到的,我们无法对其进行更新或者删除,就像下方的avg_salary
sql 复制代码
CREATE VIEW vu_emp3
AS
SELECT dept_id,AVG(salary) avg_salary
FROM t_employee
WHERE department_id IS NOT NULL
GROUP BY dept_id;
  • 视图主要是为了方便我们对数据进行查询,假设我们要对数据进行修改,那还是建议操作基表

4、修改与删除视图

1)使用CREATE OR REPLACE

假设我们需要在下面的视图中再增加一个email字段

sql 复制代码
CREATE VIEW vu_emp
AS
SELECT employee_id,last_name,salary
FROM t_employee
WHERE salary > 8000;

就可以使执行如下sql

sql 复制代码
CREATE OR REPLACE VIEW vu_emp
AS
SELECT employee_id,last_name,salary,email
FROM t_employee
WHERE salary > 8000;

2)使用ALTER VIEW,想达到上面那样的效果,就执行如下sql

sql 复制代码
ALTER VIEW vu_emp
AS
SELECT employee_id,last_name,salary,email
FROM t_employee
WHERE salary > 8000;

3)删除视图,IF EXISTS可带可不带

sql 复制代码
DROP VIEW IF EXISTS 视图名称;

另外,如果视图C是基于视图A与视图B创建的,当A与B被删除时,视图C会出现查询失败的情况

如有错误,欢迎指正!!!

相关推荐
聪聪那年228 分钟前
Oracle 11g windows 10安装与卸载
数据库·oracle
故渊ZY10 分钟前
从入门到精通:MySQL 核心技术与业务落地实践
mysql
计算机毕设匠心工作室18 分钟前
【python大数据毕设实战】全面皮肤病症状数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql
前端之虎陈随易23 分钟前
MoonBit内置数据结构详解
数据结构·数据库·redis
摆烂工程师25 分钟前
2025年12月最新的 Google AI One Pro 1年会员教育认证通关指南
前端·后端·ai编程
云和恩墨42 分钟前
AI驱动的Oracle SQL优化:从经验依赖到智能协同的三大价值
人工智能·sql·oracle·深度优先·dba
qq_12498707531 小时前
基于SpringBoot+vue的小黄蜂外卖平台(源码+论文+部署+安装)
java·开发语言·vue.js·spring boot·后端·mysql·毕业设计
CAE虚拟与现实1 小时前
C/C++中“静态链接(Static Linking)” 和 “动态链接(Dynamic Linking)释疑
开发语言·c++·dll·动态链接库·lib库
小二·1 小时前
Spring框架入门:TX 声明式事务详解
java·数据库·spring
万邦科技Lafite1 小时前
一键获取淘宝店铺所有商品信息,实时监控商品数据
开发语言·数据库·python·api·开放api·电商开放平台·淘宝开放平台