MySQL之臨時表的實現(xiàn)示例
寫在前面
本文一起看下MySQL的臨時表。
1:什么是臨時表
通過create temporary table t語句創(chuàng)建的表,就是臨時表,臨時表的臨時體現(xiàn)在其生命周期是和會話一樣的,當(dāng)會話結(jié)束,即連接關(guān)閉時MySQL會自動將創(chuàng)建的臨時表執(zhí)行刪除操作,如下:
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)
雖然臨時表的生命周期是會話級別的,但是在程序中顯式的刪除臨時表永遠(yuǎn)是一個我們必須要做的動作
(刪除也是使用drop table語句如:drop table t_tmp;),因為你不能保證任何場景下你所創(chuàng)建的臨時表都會被合理的刪除,比如使用線程池時,此時就不僅僅是臨時表沒有被刪除而占用資源的問題了,還會因為后續(xù)的程序讀取到前面程序在臨時表中的數(shù)據(jù),而造成bug,而且這種bug是很難發(fā)現(xiàn)的。所以,養(yǎng)成好習(xí)慣是很重要的。
2:臨時表和內(nèi)存表
- 內(nèi)存表
內(nèi)存表指的是存儲引擎為memory的表,建表語句是create table t()engine=memory,數(shù)據(jù)是保存在內(nèi)存中的,因此如果是重啟的話,數(shù)據(jù)不會保留,但表結(jié)構(gòu)是保留的,可以看到,內(nèi)存表就是正常的表,只不過是存儲引擎為memory,且重啟后數(shù)據(jù)不會保留,如下測試:
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)
- 臨時表
可以是任何存儲引擎,但是生命周期和會話綁定,并且不同會話可以創(chuàng)建相同名稱的臨時表,具體我們在后面繼續(xù)來分析。
3:臨時表的特點
為了便于理解,我們來看下下面這個操作序列

總結(jié)其特點如下:
1:語法是create temporary table ...
2:臨時表在會話之間是隔離的,即本會話只能看到本會話內(nèi)創(chuàng)建的臨時表
3:臨時表可以和普通表同名
4:操作時,存在同名的臨時表和普通表時,臨時表的優(yōu)先級高于普通表
5:show tables不會顯示臨時表,只顯示普通表
6:不同會話可以創(chuàng)建同名的臨時表
其中的特點6:不同會話可以創(chuàng)建同名的臨時表當(dāng)我們在實際業(yè)務(wù)代碼中需要使用中間表的業(yè)務(wù)中就非常有用了,比如在分庫分表場景中聚合不同庫和表的數(shù)據(jù),此時如果是使用普通表,那么不同的會話并行操作時肯定會出現(xiàn)表名稱重復(fù)的問題,而使用臨時表則會很好的解決這個問題。
4:為什么臨時表是可以重名的
從前面的分析中我們知道了,不同的會話臨時表名稱是可以重復(fù)的,這是為什么呢?要解釋這個問題,必須先來了解下,MySQL是如何判斷表是否存在?,每個表都有一個對應(yīng)的table_def_key,對于普通表table_def_key的定義是庫名+表名,因此普通表的表名稱不可以重復(fù),而臨時表table_def_key的規(guī)則是庫名+表名+server_id+thread_id,而其中thread_id,每個會話連接都是不一樣的,所以,臨時表是可以重名的,那么當(dāng)我們執(zhí)行語句create temporary table tttt(age int(32))engine=innodb;之后臨時表tttt的結(jié)構(gòu)和數(shù)據(jù)都是如何存儲的呢?對于結(jié)構(gòu)是在select @@tmpdir目錄下創(chuàng)建名稱為#sql{進(jìn)程 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
數(shù)據(jù)的存放,在5.7之前是在select @@tmpdir目錄下創(chuàng)建一個相同前綴的.ibd文件,5.7之后引入了臨時文件表空間,數(shù)據(jù)就存放在這里,就不需要生成ibd文件了。
寫在后面
參考文章列表:
到此這篇關(guān)于MySQL之臨時表的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)MySQL 臨時表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MySQL實戰(zhàn)文章(非常全的基礎(chǔ)入門類教程)
半個月時間把MySQL重新鞏固了一遍,梳理了一篇幾萬字超硬核文章,想學(xué)習(xí)mysql的朋友可以看看2023-05-05
mysql數(shù)據(jù)庫遷移數(shù)據(jù)目錄至另一臺服務(wù)器詳細(xì)步驟
MySQL數(shù)據(jù)庫轉(zhuǎn)移到新服務(wù)器是指將現(xiàn)有的MySQL數(shù)據(jù)庫遷移至一個新的服務(wù)器環(huán)境中,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫遷移數(shù)據(jù)目錄至另一臺服務(wù)器的詳細(xì)步驟,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07
Xtrabackup使用指南 InnoDB數(shù)據(jù)備份工具
Xtrabackup是一個對InnoDB做數(shù)據(jù)備份的工具,支持在線熱備份(備份時不影響數(shù)據(jù)讀寫),是商業(yè)備份工具InnoDB Hotbackup的一個很好的替代品2011-10-10
關(guān)于mysql調(diào)用新手們常犯的11個錯誤總結(jié)
對于很多新手們來說,使用PHP可以在短短幾個小時之內(nèi)輕松地寫出具有特定功能的代碼。但是,構(gòu)建一個穩(wěn)定可靠的數(shù)據(jù)庫卻需要花上一些時日和相關(guān)技能。下面這篇文章就來總結(jié)了關(guān)于mysql調(diào)用新手們常犯的十一個錯誤,需要的朋友可以參考學(xué)習(xí)。2017-03-03
MySQL8.0開啟遠(yuǎn)程連接權(quán)限的方法步驟
MySQL8.0設(shè)置遠(yuǎn)程訪問權(quán)限,找了一圈都沒找到一個適用的,索性自己寫一個,這篇文章主要給大家介紹了關(guān)于MySQL8.0開啟遠(yuǎn)程連接權(quán)限的方法步驟,需要的朋友可以參考下2022-06-06

