【MySQL基础篇】十二、视图的概念与操作

文章目录

Ⅰ. 视图的概念

​ 在 MySQL 中,"视图"是一种 虚拟表,它是基于一个或多个数据库表的查询结果。视图 并不实际存储数据,而是存储了一个查询的定义(即 select 语句),每当查询视图时,实际的数据都是从基础表中获取的。

​ 创建视图的主要目的是简化复杂的查询操作和隐藏基础表的结构,从而提供更简洁、易于理解的数据接口。通过使用视图,可以将复杂的查询逻辑抽象为一个命名的实体,使得查询和数据操作更加方便和有效。

​ 同真实的表一样,视图包含一系列带有名称的列和行数据。视图的数据变化会影响到基表,基表的数据变化也会影响到视图

Ⅱ. 视图的操作

1、创建视图

sql 复制代码
create view 视图名 as 
	select语句;

2、删除视图

sql 复制代码
drop view 视图名;

3、查看视图

sql 复制代码
select 列名 from 视图名 [order by ...];

案例

sql 复制代码
-- 根据之前的雇员表创建视图
mysql> create view my_view as select ename, dname from emp inner join dept on emp.deptno<=>dept.deptno;
Query OK, 0 rows affected (0.00 sec)

-- 可以看到多了一张my_view表结构
mysql> show tables;
+-----------------+
| Tables_in_scott |
+-----------------+
| dept            |
| emp             |
| my_view         |
| salgrade        |
+-----------------+
4 rows in set (0.00 sec)

-- 查看my_view表结构
mysql> select * from my_view;
+--------+------------+
| ename  | dname      |
+--------+------------+
| SMITH  | RESEARCH   |
| ALLEN  | SALES      |
| WARD   | SALES      |
| JONES  | RESEARCH   |
| MARTIN | SALES      |
| BLAKE  | SALES      |
| CLARK  | ACCOUNTING |
| SCOTT  | RESEARCH   |
| KING   | ACCOUNTING |
| TURNER | SALES      |
| ADAMS  | RESEARCH   |
| JAMES  | SALES      |
| FORD   | RESEARCH   |
| MILLER | ACCOUNTING |
+--------+------------+
14 rows in set (0.00 sec)

💥注意事项

  • 与表一样,视图必须唯一命名(不能出现同名视图或表名)
  • 创建视图数目无限制,但要考虑复杂查询创建为视图之后的性能影响
  • 视图不能添加索引,也不能有关联的触发器或者默认值
  • 视图可以提高安全性,必须具有足够的访问权限
  • order by 可以用在视图中,但是如果从该视图检索数据 select 中也含有 order by ,那么 该视图中的 order by 将被覆盖
  • 视图可以和表一起使用
  • 视图的数据变化会影响到基表,基表的数据变化也会影响到视图

实战OJ

相关推荐
AllData公司负责人3 分钟前
【亲测好用】数据集成管理能力演示
java·大数据·数据库·开源
brevity_souls4 分钟前
SQL Server 窗口函数简介
开发语言·javascript·数据库
倚-天-照-海7 分钟前
Doris数据库基本概念
数据库
翼龙云_cloud9 分钟前
阿里云渠道商:cpu 弹性扩容有哪些限制条件?
数据库·阿里云·云计算
陈聪.22 分钟前
HRCE简单实验
linux·运维·数据库
APIshop35 分钟前
实战代码解析:item_get——获取某鱼商品详情接口
java·linux·数据库
洛_尘37 分钟前
MySQL 5:增删改查操作
数据库·mysql
老邓计算机毕设1 小时前
SSM养老院老人健康信息管理系统t4p4x(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·计算机毕业设计·ssm 框架·养老院老人健康管理系统
AC赳赳老秦1 小时前
跨境科技服务的基石:DeepSeek赋能多语言技术文档与合规性说明的深度实践
android·大数据·数据库·人工智能·科技·deepseek·跨境
理智的煎蛋1 小时前
达梦数据库全流程操作指南
数据库·oracle