Mysql虚表指的是什么意思
一分耕耘,一分收获!既然都打开这篇《Mysql虚表指的是什么意思》,就坚持看下去,学下去吧!本文主要会给大家讲到等等知识点,如果大家对本文有好的建议或者看到有不足之处,非常欢迎大家积极提出!在后续文章我会继续更新数据库相关的内容,希望对大家都有所帮助!
虚拟表是实际上并不存在(物理上不存在),但是逻辑上存在的表。在mysql中,存在三种虚拟表:临时表、内存表和视图;而只能从select语句可以返回虚拟表的是视图和派生表。视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。
虚拟表,就是实际上并不存在(物理上不存在),但是逻辑上存在的表。
在MySQL中,存在的虚拟表:临时表、内存表和视图,派生表。
只能从select语句可以返回虚拟表的是视图和派生表。
一、派生表
当select语句的from子句中使用独立子查询时,就称其为派生表。
select column_list from ( select column_list from table_1 ) derived_table_name where derived_table_name.c1 > 0 ;
与子查询不同,派生表必须具有别名,以便稍后在查询中引用其名字。
如果派生表没有别名,则出错。
二、视图
视图是为了方便多个表联表查询而设计的,所以视图也是多个表中的字段由各个表中的关联关系而创建的一种虚拟表。
视图创建后就保存了下来,以后可以随时用,除非drop删除视图。
在数据库中,只存放了视图的定义,并没有存放视图的数据,数据还是存储在原来的表中,
视图的数据是依赖原来表中的数据的,所以原来表的数据发生了改变,那么显示的视图的数据也会随着改变。
一般来说,我们只是利用视图来查询数据,不会通过视图来操作数据。
1.创建视图
-- other create view other as select a.name as username, b.name as goodsname from user as a, goods as b where a.id=b.id;
2.删除视图
drop view if exists other;
3.调用视图
select * from other;
4.如果视图不存在,则创建视图;如果视图存在,则修改视图
create or replace view view_name as select 语句;
视图只需创建一次,就会在 navicat premium(MySQL可视化工具)中进行保存,无法重复创建
所以想重复调试创建视图,需先删除已创建的视图,在执行创建视图的SQL命令或者是修改视图。
视图作用:
提高了重用性,就项一个函数,创建一次,可重复调用。
对数据库重构,却不影响原数据。
让数据更加清晰。想要什么样的数据,就创建什么样的视图。
视图定义的存放位置:information_schema.views
查看视图的基本信息:DESC view_name;
注意:
修改视图的数据,将直接修改数据表(即原表)的真实数据。
删除视图,不会影响原表的数据,但是删除视图的数据,则会影响到原表。
即可以从select语句可以返回虚拟表,又可以通过构建表结构创建虚拟表的是临时表和内存表。
三、临时表
MySQL临时表在保存一些临时数据时是非常有用的。
临时表是建立在系统临时文件夹中的表,使用得当,完全可以像普通表一样进行各种操作。
临时表的数据和表结构都存储在内存中。
临时表只在当前MySQL连接可见,当关闭连接时,MySQL会自动删除表并释放所有空间。
1.通过构建临时表结构创建临时表
create temporary table tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL ); select * from tmp_table;
2.直接将查询结果导入临时表
create temporary table tmp_table select * from other;
3.删除临时表
drop table tmp_table;
临时表的应用:
当某一个SQL语句关联的表在2张及以上,并且和一些小表关联。可以通过拆分大表并将其结果存储在临时表中,获得较小的结果集合。
程序执行过程中可能需要存放一些临时数据,这些数据在整个程序的会话过程中需要重复使用。
临时表默认是MyISAM(存储引擎),但是可以修改。
注意:
临时表与存在的表名相同的时候,存在的表会被隐藏,当临时表被drop,存在的表就可见了。
show tables语句不会列举临时表,但是会列出内存表。
临时表在数据库多个连接之间不能共享。
要设定临时表最大所需内存为128MB,需要使用tmp_table_size参数。当数据超过临时表的最大值设定时,自动转为磁盘表,此时因需要进行IO操作,性能会大大下降,而内存表不会,内存表满后,会提示数据满错误。
临时表更多作用是系统自己创建或,组织数据以提升性能,如子查询。
四、内存表
表结构建在磁盘上,数据在内存里,当停止服务后,表中的数据会丢失,而表的结构不会丢失。
内存表也可以被看作是临时表的一种。
1.通过构建内存表结构创建内存表
create table tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL )ENGINE=MEMORY; select * from tmp_table; show tables;
2.直接将查询结果导入内存表
create table tmp_table engine=memory select * from other;
3.释放占用的内存
-- 删除数据 delete from tmp_table; -- 清空表 truncate table tmp_table; -- 删除表 drop table tmp_table;
内存表特征:
对于varchar等变长类型,内存表使用固定的长度来存放。
内存表可以有非唯一的键。
内存表不能包含BLOB或TEXT列。
内存表支持AUTO_INCREMENT列。
内存表支持插入延迟,使读取优先。
当临时表变得很大时,MySQL会自动地把它转化为在磁盘上存储的表,而内存表不会自动转换。
在MySQL的主从服务器上,内存表可以被复制。
内存表最大的size受限于系统变量max_heap_table_size,默认值是16MB,这个变量是可以修改的。
内存表对所有用户的连接都是可见的,使得它非常适合做缓存。
内存表必须使用memory存储引擎。
内存表的注意事项:
1、heap不允许使用xxxTEXT和xxxBLOB数据类型;只允许使用=和<=>操作符来搜索记录(不允 许& amp; lt;、>、<=或>=);mysql4.1版本之前不支持auto_increment;只允许对非空数据列进行索引(not null)。
注:操作符 “<=>” 说明:NULL-safe equal.这个操作符和“=”操作符执行相同的比较操作,不过在两个操作码均为NULL时,其所得值为1而不为NULL,而当一个操作码为NULL时,其所得值为0而不为NULL。
2、内存表可以通过max_heap_table_size = 2048M来加大使用的内存。
3、内存表必须使用memory存储引擎
五、临时内存表
1.通过构建表结构创建临时内存表
create temporary table tmp_table ( name VARCHAR(10) NOT NULL, value INTEGER NOT NULL )ENGINE=MEMORY; select * from tmp_table; show tables;
2.直接将查询结果导入内存表
create temporary table tmp_table engine=memory select * from other;
临时表使用注意事项:
当当前连接关闭时,临时表会自动删除,只在该连接中可见。这就意味着你可以在两个不同的连接里使用相同的临时表名,并且相互不会冲突,或者使用已经存在的表,但不是临时表的表名。存在的表在临时表存在时被隐藏,临时表被删除后,存在的表将重新出现。
(2)临时表只能用在 memory,myisam,merge,或者innodb引擎。
(3)临时表不支持mysql cluster(簇)。
(4)在同一个query语句中,你只能查找一次临时表。例如:下面的就不可用
mysql> SELECT * FROM temp_table, temp_table AS t2; ERROR 1137: Can't reopen table: 'temp_table'
如果在一个存储函数里,你用不同的别名查找一个临时表多次,或者在这个存储函数里用不同的语句查找,这个错误都会发生。
(5)show tables 语句不会列举临时表,但是会列出内存表。
(6)你不能用rename来重命名一个临时表。但是,你可以alter table代替:
mysql>ALTER TABLE orig_name RENAME new_name;
本篇关于《Mysql虚表指的是什么意思》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于数据库的相关知识,请关注golang学习网公众号!

- 上一篇
- Redis实现分布式语音识别的方法与应用实例

- 下一篇
- Redis与Elasticsearch的区别与使用场景
-
- 数据库 · MySQL | 20小时前 | 索引 数据类型 字符集 存储引擎 CREATETABLE
- MySQL新建表操作指南与建表技巧
- 462浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 条件判断
- CASEWHEN条件判断的嵌套使用详解与实战场景分析
- 469浏览 收藏
-
- 数据库 · MySQL | 1个月前 | java php
- CSV文件批量导入MySQL的性能优化秘籍大揭秘
- 289浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- GaleraCluster多主集群配置与冲突解决攻略
- 239浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 窗口函数实战
- MySQL窗口函数实战案例深度剖析
- 315浏览 收藏
-
- 数据库 · MySQL | 1个月前 | 自定义函数
- MySQL插件开发入门:自定义函数(UDF)编写指南
- 184浏览 收藏
-
- 数据库 · MySQL | 1个月前 |
- Windows系统MySQL8.0免安装版配置攻略
- 227浏览 收藏
-
- 数据库 · MySQL | 1个月前 | MySQL错误 数据库诊断
- 深度解析错误代码1045/1217/1205的根本原因及解决方案
- 202浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 笔灵AI生成答辩PPT
- 探索笔灵AI生成答辩PPT的强大功能,快速制作高质量答辩PPT。精准内容提取、多样模板匹配、数据可视化、配套自述稿生成,让您的学术和职场展示更加专业与高效。
- 16次使用
-
- 知网AIGC检测服务系统
- 知网AIGC检测服务系统,专注于检测学术文本中的疑似AI生成内容。依托知网海量高质量文献资源,结合先进的“知识增强AIGC检测技术”,系统能够从语言模式和语义逻辑两方面精准识别AI生成内容,适用于学术研究、教育和企业领域,确保文本的真实性和原创性。
- 24次使用
-
- AIGC检测-Aibiye
- AIbiye官网推出的AIGC检测服务,专注于检测ChatGPT、Gemini、Claude等AIGC工具生成的文本,帮助用户确保论文的原创性和学术规范。支持txt和doc(x)格式,检测范围为论文正文,提供高准确性和便捷的用户体验。
- 30次使用
-
- 易笔AI论文
- 易笔AI论文平台提供自动写作、格式校对、查重检测等功能,支持多种学术领域的论文生成。价格优惠,界面友好,操作简便,适用于学术研究者、学生及论文辅导机构。
- 42次使用
-
- 笔启AI论文写作平台
- 笔启AI论文写作平台提供多类型论文生成服务,支持多语言写作,满足学术研究者、学生和职场人士的需求。平台采用AI 4.0版本,确保论文质量和原创性,并提供查重保障和隐私保护。
- 35次使用
-
- MySQL主从切换的超详细步骤
- 2023-01-01 501浏览
-
- Mysql-普通索引的 change buffer
- 2023-01-25 501浏览
-
- MySQL高级进阶sql语句总结大全
- 2022-12-31 501浏览
-
- Mysql报错:message from server: * is blocked because of many
- 2023-02-24 501浏览
-
- 腾讯云大佬亲码“redis深度笔记”,不讲一句废话,全是精华
- 2023-02-22 501浏览