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

淺談Mysql在什么情況下會使用內(nèi)部臨時表

 更新時間:2021年10月26日 09:18:48   作者:我和寧拼啦  
內(nèi)部臨時表是一種特殊輕量級的臨時表,本文主要介紹了Mysql在什么情況下會使用內(nèi)部臨時表,具有一定的參考價值,感興趣的小伙伴們可以參考一下

union執(zhí)行

為了便于分析,使用一下sql來進(jìn)行舉例

CREATE TABLE t1 ( id INT PRIMARY KEY, a INT, b INT, INDEX ( a ) );

delimiter ;;
CREATE PROCEDURE idata ( ) BEGIN
DECLARE
        i INT;
 SET i = 1;
 WHILE
   ( i <= 1000 ) DO
   INSERT INTO t1
  VALUES
   ( i, i, i );
  SET i = i + 1;
 END WHILE;
 END;;

delimiter ;
CALL idata ( );

然后我們執(zhí)行以下sql

(select 1000 as f) union (select id from t1 order by id desc limit 2);

這段sql的語義是,取兩個子查詢的的并集,并且去重

可以看到,第二行的key是primary,說明第二個子查詢使用索引id。第三行的Extra字段,表示在子查詢union的時候,使用了臨時表(Using temporary)。
這個語句的執(zhí)行流程是這樣的:
1)創(chuàng)建一個內(nèi)存臨時表,這個臨時表只有一個整形字段f,并且f是主鍵字段
2)執(zhí)行第一個子查詢,將1000存在臨時表
3)執(zhí)行第二個子查詢,拿到第一行id=1000,并試圖插入到臨時表,但是由于1000這個值已經(jīng)存在臨時表了,違法了唯一性約束,所以插入失敗,接著取到第二行數(shù)據(jù)999,插入臨時表成功
4)從臨時表中按行取出數(shù)據(jù),返回結(jié)果,并刪除臨時表,結(jié)果中包含兩條數(shù)據(jù)就是1000和999
可以看到,臨時表起到了暫存數(shù)據(jù)的作用,而且存在唯一性約束,實現(xiàn)了union去重的語義

group by

另外一個常見的使用臨時表的例子就是group by,我們看一下以下sql

select id%10 as m, count(*) as c from t1 group by m;

這個語句就是根據(jù)t1表的數(shù)據(jù),根據(jù)id%10進(jìn)行分組,并按照m的結(jié)果排序后輸出

在Extra字段中,我們看到了三個信息:

1)Using index,表示這個語句使用了覆蓋索引,選擇了索引 a;
2)Using temporary,表示使用了臨時表;
3)Using filesort,表示需要排序;

這個語句的執(zhí)行流程是這樣的:

1)創(chuàng)建內(nèi)存臨時表,表里有字段m和c,主鍵是m;
2)掃描表t1的索引a,依次取出葉子節(jié)點上面的id值,計算id%10的結(jié)果,記為x;

  • 如果臨時表沒有主鍵x,就插入一個記錄(x,1);
  • 如果表中有主鍵x的行,就將x這一行的c值加1;

3)遍歷完成之后,再根據(jù)字段m做排序,得到結(jié)果

內(nèi)存臨時表的大小是有限制的,參數(shù)tmp_table_size就是控制這個內(nèi)存大小的,默認(rèn)是16M,如果內(nèi)存臨時表大小達(dá)到了上線,這時候就會把內(nèi)存臨時表轉(zhuǎn)成磁盤臨時表,磁盤臨時表的默認(rèn)引擎是InnoDB,如果表的數(shù)據(jù)量很大,很可能查詢就會占用大量的磁盤空間

到此這篇關(guān)于淺談Mysql在什么情況下會使用內(nèi)部臨時表的文章就介紹到這了,更多相關(guān)Mysql 內(nèi)部臨時表內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL?EXPLAIN執(zhí)行計劃解析

    MySQL?EXPLAIN執(zhí)行計劃解析

    本文主要介紹了MySQL?EXPLAIN執(zhí)行計劃解析,通過MySQL?EXPLAIN執(zhí)行計劃的各個字段的含義以及使用方式。感興趣的小伙伴可以參考一下
    2022-08-08
  • 詳解MySQL alter ignore 語法

    詳解MySQL alter ignore 語法

    這篇文章主要介紹了MySQL alter ignore 語法的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-11-11
  • mysql中的delete,drop和truncate有什么區(qū)別

    mysql中的delete,drop和truncate有什么區(qū)別

    這篇文章主要介紹了mysql中的delete,drop和truncate有什么區(qū)別,三者的用法和使用場景又完全不同,接下來我們來看看具體的區(qū)別吧,希望對你的學(xué)習(xí)有所幫助
    2022-06-06
  • MySQL下載安裝、配置與使用教程詳細(xì)版(win7x64)

    MySQL下載安裝、配置與使用教程詳細(xì)版(win7x64)

    這篇文章主要為大家詳細(xì)介紹了MySQL下載安裝、配置與使用的具體操作教程,很詳細(xì),感興趣的小伙伴們可以參考一下
    2016-05-05
  • asp采用ODBC接口訪問MySQL的方法

    asp采用ODBC接口訪問MySQL的方法

    asp采用ODBC接口訪問MySQL的方法...
    2007-07-07
  • Red?Hat?安裝MySQL?8.0與?Navicat的詳細(xì)過程

    Red?Hat?安裝MySQL?8.0與?Navicat的詳細(xì)過程

    這篇文章主要介紹了Red?Hat安裝MySQL8.0與Navicat,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • MySql索引和事務(wù)定義到使用全面涵蓋

    MySql索引和事務(wù)定義到使用全面涵蓋

    這篇文章主要介紹了MySQL數(shù)據(jù)庫索引事務(wù),索引是為了加速對表中數(shù)據(jù)行的檢索而創(chuàng)建的一種分散的存儲結(jié);事物是屬于計算機(jī)中一個很廣泛的概念,一般是指要做的或所做的事情,下面我們就一起進(jìn)入文章了解具體內(nèi)容吧
    2022-07-07
  • 在Linux系統(tǒng)安裝Mysql教程

    在Linux系統(tǒng)安裝Mysql教程

    本文給大家分享的是如何在linux下安裝mysql 圖解教程,步奏非常詳細(xì),也很實用,這里推薦給大家
    2016-04-04
  • MySQL轉(zhuǎn)換Oracle的需要注意的七個事項

    MySQL轉(zhuǎn)換Oracle的需要注意的七個事項

    有很多應(yīng)用項目, 剛起步的時候用MySQL數(shù)據(jù)庫基本上能實現(xiàn)各種功能需求,隨著應(yīng)用用戶的增多,數(shù)據(jù)量的增加,MySQL漸漸地出現(xiàn)不堪重負(fù)的情況:連接很慢甚至宕機(jī),于是就有MySQL轉(zhuǎn)換Oracle的需求,應(yīng)用程序也要相應(yīng)做一些修改。
    2010-12-12
  • mysql5.7.33誤刪除ibdata文件找回數(shù)據(jù)的方法

    mysql5.7.33誤刪除ibdata文件找回數(shù)據(jù)的方法

    這篇文章主要介紹了mysql5.7.33誤刪除ibdata文件找回數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論