MySQL之临时表的实现示例

 更新时间:2023年08月23日 10:43:41   作者:一户董  
MySQL临时表是存储在内存或者磁盘上的临时数据表,它们的生命周期只限于当前数据库会话,临时表的创建和使用方式与普通表类似,本文就详细的介绍了MySQL之临时表,感兴趣的可以了解一下

写在前面

本文一起看下MySQL的临时表。

1:什么是临时表

通过create temporary table t语句创建的表,就是临时表,临时表的临时体现在其生命周期是和会话一样的,当会话结束,即连接关闭时MySQL会自动将创建的临时表执行删除操作,如下:

mysql> create temporary table t_tmp(age int)engine=innodb;
Query OK, 0 rows affected (0.07 sec)
mysql> show create table t_tmp;
+-------+----------------------------------------------------------------------------------------------------+
| Table | Create Table                                                                                       |
+-------+----------------------------------------------------------------------------------------------------+
| t_tmp | CREATE TEMPORARY TABLE `t_tmp` (
  `age` int(11) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+-------+----------------------------------------------------------------------------------------------------+
1 row in set (0.03 sec)

虽然临时表的生命周期是会话级别的,但是在程序中显式的删除临时表永远是一个我们必须要做的动作(删除也是使用drop table语句如:drop table t_tmp;),因为你不能保证任何场景下你所创建的临时表都会被合理的删除,比如使用线程池时,此时就不仅仅是临时表没有被删除而占用资源的问题了,还会因为后续的程序读取到前面程序在临时表中的数据,而造成bug,而且这种bug是很难发现的。所以,养成好习惯是很重要的。

2:临时表和内存表

  • 内存表
    内存表指的是存储引擎为memory的表,建表语句是create table t()engine=memory,数据是保存在内存中的,因此如果是重启的话,数据不会保留,但表结构是保留的,可以看到,内存表就是正常的表,只不过是存储引擎为memory,且重启后数据不会保留,如下测试:
mysql> create table t_memory(id int primary key auto_increment)engine=memory;
Query OK, 0 rows affected (0.08 sec)
mysql> insert into t_memory value();
Query OK, 1 row affected (0.04 sec)
mysql> select * from t_memory;
+----+
| id |
+----+
|  1 |
+----+
1 row in set (0.01 sec)
// 重启
[root@localhost tmp]# service mysql restart
Shutting down MySQL............. SUCCESS! 
Starting MySQL................................................................. SUCCESS! 
// 重启后查看
mysql> show create table t_memory;
+----------+-----------------------------------------------------------------------------------------------------------------------------+
| Table    | Create Table                                                                                                                |
+----------+-----------------------------------------------------------------------------------------------------------------------------+
| t_memory | CREATE TABLE `t_memory` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=MEMORY DEFAULT CHARSET=utf8 |
+----------+-----------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
mysql> select * from t_memory;
Empty set (0.00 sec)
  • 临时表
    可以是任何存储引擎,但是生命周期和会话绑定,并且不同会话可以创建相同名称的临时表,具体我们在后面继续来分析。

3:临时表的特点

为了便于理解,我们来看下下面这个操作序列

总结其特点如下:

1:语法是create temporary table ...
2:临时表在会话之间是隔离的,即本会话只能看到本会话内创建的临时表
3:临时表可以和普通表同名
4:操作时,存在同名的临时表和普通表时,临时表的优先级高于普通表
5:show tables不会显示临时表,只显示普通表
6:不同会话可以创建同名的临时表

其中的特点6:不同会话可以创建同名的临时表当我们在实际业务代码中需要使用中间表的业务中就非常有用了,比如在分库分表场景中聚合不同库和表的数据,此时如果是使用普通表,那么不同的会话并行操作时肯定会出现表名称重复的问题,而使用临时表则会很好的解决这个问题。

4:为什么临时表是可以重名的

从前面的分析中我们知道了,不同的会话临时表名称是可以重复的,这是为什么呢?要解释这个问题,必须先来了解下,MySQL是如何判断表是否存在?,每个表都有一个对应的table_def_key,对于普通表table_def_key的定义是库名+表名,因此普通表的表名称不可以重复,而临时表table_def_key的规则是库名+表名+server_id+thread_id,而其中thread_id,每个会话连接都是不一样的,所以,临时表是可以重名的,那么当我们执行语句create temporary table tttt(age int(32))engine=innodb;之后临时表tttt的结构和数据都是如何存储的呢?对于结构是在select @@tmpdir目录下创建名称为#sql{进程 id}_{线程 id}_序列号.frm的文件,如下:

[root@localhost tmp]# mysql -uroot -p -e"select @@tmpdir"
Enter password: 
+----------+
| @@tmpdir |
+----------+
| /tmp     |
+----------+
[root@localhost tmp]# pwd
/tmp
[root@localhost tmp]# ll | egrep '#sql'
-rw-r----- 1 mysql mysql    8558 Sep  2 16:50 #sql105b4_3_0.frm

数据的存放,在5.7之前是在select @@tmpdir目录下创建一个相同前缀的.ibd文件,5.7之后引入了临时文件表空间,数据就存放在这里,就不需要生成ibd文件了。

写在后面

参考文章列表:

MySQL 临时表 

到此这篇关于MySQL之临时表的实现示例的文章就介绍到这了,更多相关MySQL 临时表内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL实战文章(非常全的基础入门类教程)

    MySQL实战文章(非常全的基础入门类教程)

    半个月时间把MySQL重新巩固了一遍,梳理了一篇几万字超硬核文章,想学习mysql的朋友可以看看
    2023-05-05
  • MySQL 搭建MHA架构部署的步骤

    MySQL 搭建MHA架构部署的步骤

    这篇文章主要介绍了MySQL 搭建MHA架构部署的步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • mysql 存储过程的问题

    mysql 存储过程的问题

    最近我接触了一本php 与 mysql,老外写的一本书,书中有个tshirtshop网店代码,其中操作数据库的大多用的是mysql存储过程
    2009-06-06
  • MySQL隐式转换造成索引失效的解决办法

    MySQL隐式转换造成索引失效的解决办法

    数据库优化是一个任重而道远的任务,想要做优化必须深入理解数据库的各种特性,在开发过程中我们经常会遇到一些原因很简单但造成的后果却很严重的疑难杂症,这类问题往往还不容易定位,本文将给大家介绍MySQL隐式转换造成索引失效的解决办法,需要的朋友可以参考下
    2025-02-02
  • MySQL主键生成的四种方式及对比详解

    MySQL主键生成的四种方式及对比详解

    在数据库设计中,主键(Primary Key)的选择至关重要,它不仅是数据行的唯一标识,还直接影响查询效率、数据存储甚至系统架构的扩展性,本文给大家分析了常见四种主键ID生成的方式,需要的朋友可以参考下
    2025-03-03
  • mysql数据库迁移数据目录至另一台服务器详细步骤

    mysql数据库迁移数据目录至另一台服务器详细步骤

    MySQL数据库转移到新服务器是指将现有的MySQL数据库迁移至一个新的服务器环境中,下面这篇文章主要给大家介绍了关于mysql数据库迁移数据目录至另一台服务器的详细步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-07-07
  • Xtrabackup使用指南 InnoDB数据备份工具

    Xtrabackup使用指南 InnoDB数据备份工具

    Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品
    2011-10-10
  • 关于mysql调用新手们常犯的11个错误总结

    关于mysql调用新手们常犯的11个错误总结

    对于很多新手们来说,使用PHP可以在短短几个小时之内轻松地写出具有特定功能的代码。但是,构建一个稳定可靠的数据库却需要花上一些时日和相关技能。下面这篇文章就来总结了关于mysql调用新手们常犯的十一个错误,需要的朋友可以参考学习。
    2017-03-03
  • MySQL8.0开启远程连接权限的方法步骤

    MySQL8.0开启远程连接权限的方法步骤

    MySQL8.0设置远程访问权限,找了一圈都没找到一个适用的,索性自己写一个,这篇文章主要给大家介绍了关于MySQL8.0开启远程连接权限的方法步骤,需要的朋友可以参考下
    2022-06-06
  • MySQL随机查询记录的效率测试分析

    MySQL随机查询记录的效率测试分析

    以下的文章主要介绍的是MySQL使用rand 随机查询记录效率测试,我们大家一直都以为MySQL数据库随机查询的几条数据,就用以下的东东,其实其实际效率是十分低的
    2011-06-06

最新评论