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

Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法詳解

 更新時間:2023年02月09日 14:36:32   作者:云深n不知處  
項目中有需要,使用MySQL的in子查詢,查詢符合in子查詢集合中條件的數(shù)據(jù),但是沒想到的是,MySQL的in子查詢會如此的慢,讓人無法接受,下面這篇文章主要給大家介紹了關(guān)于Mysql查詢優(yōu)化之IN子查詢優(yōu)化的相關(guān)資料,需要的朋友可以參考下

物化表

首先提出一個不相關(guān)的IN子查詢

SELECT * FROM s1 
 WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = 'a');

對于不相關(guān)的 IN 子查詢來說,如果子查詢的結(jié)果集中的記錄條數(shù)很少,那么把子查詢和外層

查詢分別看成兩個單獨的單表查詢效率還是蠻高的,但是如果單獨執(zhí)行子查詢后的結(jié)果集太多的話,就會導致這
些問題:

  • 結(jié)果集太多,可能內(nèi)存中都放不下~
  • 對于外層查詢來說,如果子查詢的結(jié)果集太多,那就意味著 IN 子句中的參數(shù)特別多,這就導致:

無法有效的使用索引,只能對外層查詢進行全表掃描。
在對外層查詢執(zhí)行全表掃描時,由于 IN 子句中的參數(shù)太多,這會導致檢測一條記錄是否符合和 IN 子句中的參數(shù)匹配花費的時間太長。
比如說 IN 子句中的參數(shù)只有兩個:
SELECT * FROM tbl_name WHERE column IN (a, b);
這樣相當于需要對 tbl_name 表中的每條記錄判斷一下它的 column 列是否符合 column = a OR column= b 。在 IN 子句中的參數(shù)比較少時這并不是什么問題,如果 IN 子句中的參數(shù)比較多時,比如這樣:
SELECT * FROM tbl_name WHERE column IN (a, b, c …, …);
那么這樣每條記錄需要判斷一下它的 column 列是否符合 column = a OR column = b OR column = c
OR … ,這樣性能耗費可就多了。

所以提出一個解決方案:不直接將不相關(guān)子查詢的結(jié)果集當作外層查詢的參數(shù),而是將該結(jié)果集寫入一個臨時表里。

臨時表的特性:

  1. 該臨時表的列就是子查詢結(jié)果集中的列。
  2. 寫入臨時表的記錄會被去重。
  3. 一般情況下子查詢結(jié)果集不會大的離譜,所以會為它建立基于內(nèi)存的使用 Memory 存儲引擎的臨時表,而且會為該表建立哈希索引。
  4. 如果子查詢的結(jié)果集非常大,超過了系統(tǒng)變量 tmp_table_size 或者 max_heap_table_size ,臨時表會轉(zhuǎn)而
    使用基于磁盤的存儲引擎來保存結(jié)果集中的記錄,索引類型也對應轉(zhuǎn)變?yōu)?B+ 樹索引。
    這個將子查詢結(jié)果集中的記錄保存到臨時表的過程稱之為 物化。

物化表轉(zhuǎn)連接

當我們把子查詢進行物化之后,假設(shè)子查詢物化表的名稱為 materialized_table ,該物化表存儲的子查詢結(jié)果集的列為 m_val ,那么這個查詢其實可以從下邊兩種角度來看待:

SELECT * FROM s1
WHERE key1 IN (SELECT common_field FROM s2 WHERE key3 = ‘a(chǎn)');

從表 s1 的角度來看待,整個查詢的意思其實是:對于 s1 表中的每條記錄來說,如果該記錄的 key1 列的值

在子查詢對應的物化表中,則該記錄會被加入最終的結(jié)果集。畫個圖表示一下就是這樣:

從子查詢物化表的角度來看待,整個查詢的意思其實是:對于子查詢物化表的每個值來說,如果能在 s1 表
中找到對應的 key1 列的值與該值相等的記錄,那么就把這些記錄加入到最終的結(jié)果集。

也就是說其實上邊的查詢就相當于表 s1 和子查詢物化表 materialized_table 進行內(nèi)連接:

SELECT s1.* FROM s1 INNER JOIN materialized_table ON key1 = m_val;

如果使用 s1 表作為驅(qū)動表的話,總查詢成本由下邊幾個部分組成:

  1. 物化子查詢時需要的成本
  2. 掃描 s1 表時的成本
  3. s1表中的記錄數(shù)量 × 通過 m_val = xxx 對 materialized_table 表進行單表訪問的成本(物化表中的記錄是不重復的,并且為物化表中的列建立了索引,所以這個步驟顯然是非??斓模?/li>

如果使用 materialized_table 表作為驅(qū)動表的話,總查詢成本由下邊幾個部分組成:

  1. 物化子查詢時需要的成本
  2. 掃描物化表時的成本
  3. 物化表中的記錄數(shù)量 × 通過 key1 = xxx 對 s1 表進行單表訪問的成本

總結(jié)

到此這篇關(guān)于Mysql查詢優(yōu)化之IN子查詢優(yōu)化方法的文章就介紹到這了,更多相關(guān)Mysql IN子查詢優(yōu)化內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • windows10+mysql8.0.11zip安裝教程詳解

    windows10+mysql8.0.11zip安裝教程詳解

    這篇文章主要介紹了windows10+mysql8.0.11zip安裝教程詳解,本文給大家介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下
    2018-05-05
  • 本地windows安裝兩個mysql服務器,配置主從同步

    本地windows安裝兩個mysql服務器,配置主從同步

    大型網(wǎng)站為了緩解大量的并發(fā)訪問,除了在網(wǎng)站實現(xiàn)分布式負載均衡,還會搭建服務器mysql集群技術(shù),來分擔主數(shù)據(jù)庫的壓力。在本地電腦能實現(xiàn)這樣的技術(shù)嗎,本地windows安裝兩個mysql服務器,配置主從同步也是可以實現(xiàn)的,快來跟著教程測試一下吧。
    2022-12-12
  • 淺談MySQL臨時表與派生表

    淺談MySQL臨時表與派生表

    MySQL在處理請求的某些場景中,服務器創(chuàng)建內(nèi)部臨時表。即表以MEMORY引擎在內(nèi)存中處理,或以MyISAM引擎儲存在磁盤上處理.如果表過大,服務器可能會把內(nèi)存中的臨時表轉(zhuǎn)存在磁盤上。
    2017-02-02
  • mysql批量執(zhí)行sql文件的方法

    mysql批量執(zhí)行sql文件的方法

    下面小編就為大家?guī)硪黄猰ysql批量執(zhí)行sql文件的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編 過來看看吧
    2016-10-10
  • mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決

    mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決

    這篇文章主要介紹了mysql數(shù)據(jù)插入覆蓋和時間戳的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 將MySQL數(shù)據(jù)庫移植為PostgreSQL

    將MySQL數(shù)據(jù)庫移植為PostgreSQL

    PostgreSQL 作為功能最強勁的開源 OO 數(shù)據(jù)庫,仿佛一直不為國內(nèi)用戶所熟識。而我個人也僅是因為工作的緣故接觸到這款超經(jīng)典的數(shù)據(jù)庫,并深為之折服。
    2009-07-07
  • 關(guān)于MYSQL 你需要知道的數(shù)據(jù)類型和操作數(shù)據(jù)表

    關(guān)于MYSQL 你需要知道的數(shù)據(jù)類型和操作數(shù)據(jù)表

    這篇文章主要介紹了關(guān)于MYSQL中數(shù)據(jù)類型的知識和操作數(shù)據(jù)表的方法,文中講解非常詳細供大家參考學習,感興趣的朋友可以了解下
    2020-06-06
  • MySQL Workbench的使用方法(圖文)

    MySQL Workbench的使用方法(圖文)

    這篇文章主要介紹了MySQL Workbench的使用方法(圖文) ,需要的朋友可以參考下
    2016-02-02
  • MySQL 查看事務和鎖情況的常用語句分享

    MySQL 查看事務和鎖情況的常用語句分享

    這篇文章主要介紹了MySQL 查看事務和鎖情況的常用語句分享,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • MySQL緩存的查詢和清除命令使用詳解

    MySQL緩存的查詢和清除命令使用詳解

    這篇文章主要介紹了MySQL緩存的查詢和清除命令使用詳解,對于一些不常改變數(shù)據(jù)且有大量相同sql查詢的表,查詢緩存會顯得比較有用一些,需要的朋友可以參考下
    2015-12-12

最新評論