当前位置: 首页 > MySQL数据库

Mysql虚表指的是什么意思

时间:2026-01-25 16:19:41

虚拟表是实际上并不存在(物理上不存在),但是逻辑上存在的表。在mysql中,存在三种虚拟表:临时表、内存表和视图;而只能从select语句可以返回虚拟表的是视图和派生表。视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。

虚拟表,就是实际上并不存在(物理上不存在),但是逻辑上存在的表。

在MySQL中,存在的虚拟表:临时表、内存表和视图,派生表。

只能从select语句可以返回虚拟表的是视图和派生表。

一、派生表

当select语句的from子句中使用独立子查询时,就称其为派生表。

selectcolumn_listfrom(selectcolumn_listfromtable_1)derived_table_namewherederived_table_name.c1>0;

与子查询不同,派生表必须具有别名,以便稍后在查询中引用其名字。

如果派生表没有别名,则出错。

二、视图

视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。

视图创建后就保存了下来,以后可以随时用,除非drop删除视图。

在数据库中,只存放了视图的定义,并没有存放视图的数据,数据还是存储在原来的表中,

视图的数据是依赖原来表中的数据的,所以原来表的数据发生了改变,那么显示的视图的数据也会随着改变。

一般来说,我们只是利用视图来查询数据,不会通过视图来操作数据。

1.创建视图

--othercreateviewotherasselecta.nameasusername,b.nameasgoodsnamefromuserasa,goodsasbwherea.id=b.id;

2.删除视图

dropviewifexistsother;

3.调用视图

select*fromother;

4.如果视图不存在,则创建视图;如果视图存在,则修改视图

createorreplaceviewview_nameasselect语句;

视图创建一遍后会在navicat premium(MySQL可视化工具)保存下来,不可重复创建视图,

所以想重复调试创建视图,需先删除已创建的视图,在执行创建视图的SQL命令或者是修改视图。

视图作用:

  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素