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

詳解Mysql函數(shù)調用優(yōu)化

 更新時間:2021年04月06日 14:14:45   作者:一只小碼農(nóng)正在路過  
這篇文章主要介紹了Mysql 函數(shù)調用優(yōu)化的相關資料,幫助大家更好的理解和學習使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下

函數(shù)調用優(yōu)化

MySQL函數(shù)在內部被標記為確定性或不確定性。如果給定參數(shù)固定值的函數(shù)可以為不同的調用返回不同的結果,則它是不確定的。不確定函數(shù)的示例: RAND(), UUID()。

如果某個函數(shù)被標記為不確定的,則將WHERE針對每一行(從一個表中選擇時)或行的組合(從多表聯(lián)接中選擇時)評估子句中對該函數(shù)的引用。

MySQL還根據(jù)參數(shù)的類型(參數(shù)是表列還是常量值)確定何時評估函數(shù)。每當表列更改值時,都必須評估將表列作為參數(shù)的確定性函數(shù)。

非確定性函數(shù)可能會影響查詢性能。例如,某些優(yōu)化可能不可用,或者可能需要更多鎖定。以下討論使用 RAND()但也適用于其他不確定性函數(shù)。

假設一個表t具有以下定義:

CREATE TABLE t (id INT NOT NULL PRIMARY KEY, col_a VARCHAR(100));

考慮以下兩個查詢:

SELECT * FROM t WHERE id = POW(1,2);
SELECT * FROM t WHERE id = FLOOR(1 + RAND() * 49);

由于與主鍵的相等性比較,兩個查詢似乎都使用了主鍵查找,但這僅適用于第一個查詢:

  • 第一個查詢始終最多產(chǎn)生一行,因為POW()帶有常量參數(shù)的常量是一個常量值,并用于索引查找。
  • 第二個查詢包含一個使用非確定性函數(shù)的表達式,該表達式 RAND()在查詢中不是常量,但實際上對表的每一行都有一個新值t。因此,查詢讀取表的每一行,評估每一行的謂詞,并輸出主鍵與隨機值匹配的所有行。根據(jù)id列值和RAND()序列中的值, 它可以是零行,一行或多行 。

非確定性的影響不僅限于 SELECT陳述。該 UPDATE語句使用非確定性函數(shù)來選擇要修改的行:

UPDATE t SET col_a = some_expr WHERE id = FLOOR(1 + RAND() * 49);

大概目的是最多更新主鍵與表達式匹配的一行。但是,它可能會更新零,一或多個行,具體取決于 id列值和RAND()序列中的值 。

剛剛描述的行為對性能和復制有影響:

  • 由于不確定函數(shù)不會產(chǎn)生恒定值,因此優(yōu)化器無法使用其他可能適用的策略,例如索引查找。結果可能是表掃描。
  • InnoDB 可能升級為范圍鍵鎖,而不是為一個匹配的行獲取單行鎖。
  • 無法確定執(zhí)行的更新對于復制是不安全的。

困難源于RAND()對表的每一行都對函數(shù)進行一次評估的事實 。為了避免進行多功能評估,請使用以下技術之一:

  • 將包含不確定性函數(shù)的表達式移到單獨的語句,將值保存在變量中。在原始語句中,將表達式替換為對變量的引用,優(yōu)化器可以將該變量視為常量值:
SET @keyval = FLOOR(1 + RAND() * 49);
UPDATE t SET col_a = some_expr WHERE id = @keyval;
  • 將隨機值分配給派生表中的變量。此技術使變量在WHERE子句中的比較中使用之前被分配一個值 :
SET optimizer_switch = 'derived_merge=off';
UPDATE t, (SELECT @keyval := FLOOR(1 + RAND() * 49)) AS dt
SET col_a = some_expr WHERE id = @keyval;

如前所述,該WHERE子句中的不確定性表達式 可能會阻止優(yōu)化并導致表掃描。但是,WHERE如果其他表達式是確定性的,則可以部分優(yōu)化該子句。例如:

SELECT * FROM t WHERE partial_key=5 AND some_column=RAND();

如果優(yōu)化器可以partial_key用來減少所選行的集合, RAND()則執(zhí)行的次數(shù)更少,這可以減少不確定性對優(yōu)化的影響。

以上就是詳解Mysql 函數(shù)調用優(yōu)化的詳細內容,更多關于Mysql 函數(shù)調用優(yōu)化的資料請關注腳本之家其它相關文章!

相關文章

  • 查看MySQL初始密碼并修改的正確方式

    查看MySQL初始密碼并修改的正確方式

    這篇文章主要給大家介紹了關于查看MySQL初始密碼并修改的正確方式,MySQL是一款廣泛使用的開源關系型數(shù)據(jù)庫管理系統(tǒng),安裝后找回初始密碼是MySQL使用中的一個基礎問題,需要的朋友可以參考下
    2023-10-10
  • MySQL中RANK()函數(shù)的介紹和用法

    MySQL中RANK()函數(shù)的介紹和用法

    這篇文章主要介紹了MySQL中RANK()的介紹和用法,通過RANK()函數(shù),我們可以方便地為查詢結果進行排序并為每個行分配排名,本文介紹了RANK()函數(shù)的概念和使用方法,并通過示例和輸出結果向讀者展示了具體的操作步驟和效果,感興趣的朋友一起看看吧
    2023-07-07
  • MySQL的事務的基本要素和事務隔離級別詳解

    MySQL的事務的基本要素和事務隔離級別詳解

    這篇文章主要介紹了MySQL的事務的基本要素和事務隔離級別,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • 一文詳解MySQL主從同步原理

    一文詳解MySQL主從同步原理

    這篇文章主要介紹了一文詳解MySQL主從同步原理,MySQL主從同步是基于Bin?Log實現(xiàn)的,而Bin?Log記錄的是原始SQL語句,更多相關內容介紹感興趣的小伙伴可以參考一下
    2022-08-08
  • MySQL查詢語句大全集錦

    MySQL查詢語句大全集錦

    這篇文章主要介紹了MySQL查詢語句大全集錦,需要的朋友可以參考下
    2016-06-06
  • mysql之臟讀、不可重復讀、幻讀的區(qū)別及說明

    mysql之臟讀、不可重復讀、幻讀的區(qū)別及說明

    這篇文章主要介紹了mysql之臟讀、不可重復讀、幻讀的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • MySQL表類型 存儲引擎 的選擇

    MySQL表類型 存儲引擎 的選擇

    這篇文章主要介紹了MySQL表類型存儲引擎的選擇,文章圍繞MySQL表類型存儲引擎的選擇的相關資料展開內容,需要的朋友可以參考一下,希望對你有所幫助
    2021-11-11
  • mysql排序ORDER BY不生效的問題解決

    mysql排序ORDER BY不生效的問題解決

    order by作為一個常用的功能,在項目中應該經(jīng)常用到,本文主要介紹了mysql排序ORDER BY不生效的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • MySQL中查詢當前時間間隔前1天的數(shù)據(jù)

    MySQL中查詢當前時間間隔前1天的數(shù)據(jù)

    實際項目中我們都會遇到分布式定時任務執(zhí)行的情況,今天通過本文給大家分享MySQL中查詢當前時間間隔前1天的數(shù)據(jù),查詢sql語句給大家介紹的非常詳細,感興趣的朋友跟隨小編一起看看吧<BR>
    2021-12-12
  • MySQL數(shù)據(jù)庫中的TRUNCATE?TABLE命令詳解

    MySQL數(shù)據(jù)庫中的TRUNCATE?TABLE命令詳解

    這篇文章主要給大家介紹了關于MySQL數(shù)據(jù)庫中TRUNCATE?TABLE命令的相關資料,Truncate Table“清空表”的意思,它對數(shù)據(jù)庫中的表進行清空操作,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2024-05-05

最新評論