欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL之臨時(shí)表的實(shí)現(xiàn)示例

 更新時(shí)間:2023年08月23日 10:43:41   作者:一戶董  
MySQL臨時(shí)表是存儲(chǔ)在內(nèi)存或者磁盤上的臨時(shí)數(shù)據(jù)表,它們的生命周期只限于當(dāng)前數(shù)據(jù)庫(kù)會(huì)話,臨時(shí)表的創(chuàng)建和使用方式與普通表類似,本文就詳細(xì)的介紹了MySQL之臨時(shí)表,感興趣的可以了解一下

寫在前面

本文一起看下MySQL的臨時(shí)表。

1:什么是臨時(shí)表

通過(guò)create temporary table t語(yǔ)句創(chuàng)建的表,就是臨時(shí)表,臨時(shí)表的臨時(shí)體現(xiàn)在其生命周期是和會(huì)話一樣的,當(dāng)會(huì)話結(jié)束,即連接關(guān)閉時(shí)MySQL會(huì)自動(dòng)將創(chuàng)建的臨時(shí)表執(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)

雖然臨時(shí)表的生命周期是會(huì)話級(jí)別的,但是在程序中顯式的刪除臨時(shí)表永遠(yuǎn)是一個(gè)我們必須要做的動(dòng)作(刪除也是使用drop table語(yǔ)句如:drop table t_tmp;),因?yàn)槟悴荒鼙WC任何場(chǎng)景下你所創(chuàng)建的臨時(shí)表都會(huì)被合理的刪除,比如使用線程池時(shí),此時(shí)就不僅僅是臨時(shí)表沒(méi)有被刪除而占用資源的問(wèn)題了,還會(huì)因?yàn)楹罄m(xù)的程序讀取到前面程序在臨時(shí)表中的數(shù)據(jù),而造成bug,而且這種bug是很難發(fā)現(xiàn)的。所以,養(yǎng)成好習(xí)慣是很重要的。

2:臨時(shí)表和內(nèi)存表

  • 內(nèi)存表
    內(nèi)存表指的是存儲(chǔ)引擎為memory的表,建表語(yǔ)句是create table t()engine=memory,數(shù)據(jù)是保存在內(nèi)存中的,因此如果是重啟的話,數(shù)據(jù)不會(huì)保留,但表結(jié)構(gòu)是保留的,可以看到,內(nèi)存表就是正常的表,只不過(guò)是存儲(chǔ)引擎為memory,且重啟后數(shù)據(jù)不會(huì)保留,如下測(cè)試:
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)
  • 臨時(shí)表
    可以是任何存儲(chǔ)引擎,但是生命周期和會(huì)話綁定,并且不同會(huì)話可以創(chuàng)建相同名稱的臨時(shí)表,具體我們?cè)诤竺胬^續(xù)來(lái)分析。

3:臨時(shí)表的特點(diǎn)

為了便于理解,我們來(lái)看下下面這個(gè)操作序列

總結(jié)其特點(diǎn)如下:

1:語(yǔ)法是create temporary table ...
2:臨時(shí)表在會(huì)話之間是隔離的,即本會(huì)話只能看到本會(huì)話內(nèi)創(chuàng)建的臨時(shí)表
3:臨時(shí)表可以和普通表同名
4:操作時(shí),存在同名的臨時(shí)表和普通表時(shí),臨時(shí)表的優(yōu)先級(jí)高于普通表
5:show tables不會(huì)顯示臨時(shí)表,只顯示普通表
6:不同會(huì)話可以創(chuàng)建同名的臨時(shí)表

其中的特點(diǎn)6:不同會(huì)話可以創(chuàng)建同名的臨時(shí)表當(dāng)我們?cè)趯?shí)際業(yè)務(wù)代碼中需要使用中間表的業(yè)務(wù)中就非常有用了,比如在分庫(kù)分表場(chǎng)景中聚合不同庫(kù)和表的數(shù)據(jù),此時(shí)如果是使用普通表,那么不同的會(huì)話并行操作時(shí)肯定會(huì)出現(xiàn)表名稱重復(fù)的問(wèn)題,而使用臨時(shí)表則會(huì)很好的解決這個(gè)問(wèn)題。

4:為什么臨時(shí)表是可以重名的

從前面的分析中我們知道了,不同的會(huì)話臨時(shí)表名稱是可以重復(fù)的,這是為什么呢?要解釋這個(gè)問(wèn)題,必須先來(lái)了解下,MySQL是如何判斷表是否存在?,每個(gè)表都有一個(gè)對(duì)應(yīng)的table_def_key,對(duì)于普通表table_def_key的定義是庫(kù)名+表名,因此普通表的表名稱不可以重復(fù),而臨時(shí)表table_def_key的規(guī)則是庫(kù)名+表名+server_id+thread_id,而其中thread_id,每個(gè)會(huì)話連接都是不一樣的,所以,臨時(shí)表是可以重名的,那么當(dāng)我們執(zhí)行語(yǔ)句create temporary table tttt(age int(32))engine=innodb;之后臨時(shí)表tttt的結(jié)構(gòu)和數(shù)據(jù)都是如何存儲(chǔ)的呢?對(duì)于結(jié)構(gòu)是在select @@tmpdir目錄下創(chuàng)建名稱為#sql{進(jìn)程 id}_{線程 id}_序列號(hào).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)建一個(gè)相同前綴的.ibd文件,5.7之后引入了臨時(shí)文件表空間,數(shù)據(jù)就存放在這里,就不需要生成ibd文件了。

寫在后面

參考文章列表:

MySQL 臨時(shí)表 

到此這篇關(guān)于MySQL之臨時(shí)表的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)MySQL 臨時(shí)表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL實(shí)戰(zhàn)文章(非常全的基礎(chǔ)入門類教程)

    MySQL實(shí)戰(zhàn)文章(非常全的基礎(chǔ)入門類教程)

    半個(gè)月時(shí)間把MySQL重新鞏固了一遍,梳理了一篇幾萬(wàn)字超硬核文章,想學(xué)習(xí)mysql的朋友可以看看
    2023-05-05
  • MySQL 搭建MHA架構(gòu)部署的步驟

    MySQL 搭建MHA架構(gòu)部署的步驟

    這篇文章主要介紹了MySQL 搭建MHA架構(gòu)部署的步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • mysql 存儲(chǔ)過(guò)程的問(wèn)題

    mysql 存儲(chǔ)過(guò)程的問(wèn)題

    最近我接觸了一本php 與 mysql,老外寫的一本書,書中有個(gè)tshirtshop網(wǎng)店代碼,其中操作數(shù)據(jù)庫(kù)的大多用的是mysql存儲(chǔ)過(guò)程
    2009-06-06
  • MySQL隱式轉(zhuǎn)換造成索引失效的解決辦法

    MySQL隱式轉(zhuǎn)換造成索引失效的解決辦法

    數(shù)據(jù)庫(kù)優(yōu)化是一個(gè)任重而道遠(yuǎn)的任務(wù),想要做優(yōu)化必須深入理解數(shù)據(jù)庫(kù)的各種特性,在開發(fā)過(guò)程中我們經(jīng)常會(huì)遇到一些原因很簡(jiǎn)單但造成的后果卻很嚴(yán)重的疑難雜癥,這類問(wèn)題往往還不容易定位,本文將給大家介紹MySQL隱式轉(zhuǎn)換造成索引失效的解決辦法,需要的朋友可以參考下
    2025-02-02
  • MySQL主鍵生成的四種方式及對(duì)比詳解

    MySQL主鍵生成的四種方式及對(duì)比詳解

    在數(shù)據(jù)庫(kù)設(shè)計(jì)中,主鍵(Primary Key)的選擇至關(guān)重要,它不僅是數(shù)據(jù)行的唯一標(biāo)識(shí),還直接影響查詢效率、數(shù)據(jù)存儲(chǔ)甚至系統(tǒng)架構(gòu)的擴(kuò)展性,本文給大家分析了常見四種主鍵ID生成的方式,需要的朋友可以參考下
    2025-03-03
  • mysql數(shù)據(jù)庫(kù)遷移數(shù)據(jù)目錄至另一臺(tái)服務(wù)器詳細(xì)步驟

    mysql數(shù)據(jù)庫(kù)遷移數(shù)據(jù)目錄至另一臺(tái)服務(wù)器詳細(xì)步驟

    MySQL數(shù)據(jù)庫(kù)轉(zhuǎn)移到新服務(wù)器是指將現(xiàn)有的MySQL數(shù)據(jù)庫(kù)遷移至一個(gè)新的服務(wù)器環(huán)境中,下面這篇文章主要給大家介紹了關(guān)于mysql數(shù)據(jù)庫(kù)遷移數(shù)據(jù)目錄至另一臺(tái)服務(wù)器的詳細(xì)步驟,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-07-07
  • Xtrabackup使用指南 InnoDB數(shù)據(jù)備份工具

    Xtrabackup使用指南 InnoDB數(shù)據(jù)備份工具

    Xtrabackup是一個(gè)對(duì)InnoDB做數(shù)據(jù)備份的工具,支持在線熱備份(備份時(shí)不影響數(shù)據(jù)讀寫),是商業(yè)備份工具InnoDB Hotbackup的一個(gè)很好的替代品
    2011-10-10
  • 關(guān)于mysql調(diào)用新手們常犯的11個(gè)錯(cuò)誤總結(jié)

    關(guān)于mysql調(diào)用新手們常犯的11個(gè)錯(cuò)誤總結(jié)

    對(duì)于很多新手們來(lái)說(shuō),使用PHP可以在短短幾個(gè)小時(shí)之內(nèi)輕松地寫出具有特定功能的代碼。但是,構(gòu)建一個(gè)穩(wěn)定可靠的數(shù)據(jù)庫(kù)卻需要花上一些時(shí)日和相關(guān)技能。下面這篇文章就來(lái)總結(jié)了關(guān)于mysql調(diào)用新手們常犯的十一個(gè)錯(cuò)誤,需要的朋友可以參考學(xué)習(xí)。
    2017-03-03
  • MySQL8.0開啟遠(yuǎn)程連接權(quán)限的方法步驟

    MySQL8.0開啟遠(yuǎn)程連接權(quán)限的方法步驟

    MySQL8.0設(shè)置遠(yuǎn)程訪問(wèn)權(quán)限,找了一圈都沒(méi)找到一個(gè)適用的,索性自己寫一個(gè),這篇文章主要給大家介紹了關(guān)于MySQL8.0開啟遠(yuǎn)程連接權(quán)限的方法步驟,需要的朋友可以參考下
    2022-06-06
  • MySQL隨機(jī)查詢記錄的效率測(cè)試分析

    MySQL隨機(jī)查詢記錄的效率測(cè)試分析

    以下的文章主要介紹的是MySQL使用rand 隨機(jī)查詢記錄效率測(cè)試,我們大家一直都以為MySQL數(shù)據(jù)庫(kù)隨機(jī)查詢的幾條數(shù)據(jù),就用以下的東東,其實(shí)其實(shí)際效率是十分低的
    2011-06-06

最新評(píng)論