好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 詳解Mysql函數調用優化

詳解Mysql函數調用優化

熱門標簽:400電話辦理服務價格最實惠 html地圖標注并導航 北京金倫外呼系統 南太平洋地圖標注 武漢電銷機器人電話 催天下外呼系統 大豐地圖標注app 呂梁外呼系統 400電話變更申請

函數調用優化

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

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

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

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

假設一個表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);

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

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

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

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

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

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

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

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

  • 將包含不確定性函數的表達式移到單獨的語句,將值保存在變量中。在原始語句中,將表達式替換為對變量的引用,優化器可以將該變量視為常量值:
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子句中的不確定性表達式 可能會阻止優化并導致表掃描。但是,WHERE如果其他表達式是確定性的,則可以部分優化該子句。例如:

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

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

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

您可能感興趣的文章:
  • MySQL空間數據存儲及函數
  • MySQL中日期型單行函數代碼詳解
  • MySql關于null的函數使用分享
  • Mysql基礎之常見函數
  • MySQL中sum函數使用的實例教程
  • MySQL處理JSON常見函數的使用
  • MySQL DATE_ADD和ADDDATE函數實現向日期添加指定時間間隔
  • 淺談MySQL函數

標簽:迪慶 徐州 龍巖 自貢 無錫 西寧 南充 麗水

巨人網絡通訊聲明:本文標題《詳解Mysql函數調用優化》,本文關鍵詞  詳解,Mysql,函數,調用,優化,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《詳解Mysql函數調用優化》相關的同類信息!
  • 本頁收集關于詳解Mysql函數調用優化的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 亚洲欧美91| IJZZIJZZIJ亚洲大全| 久久久精品456亚洲影院| 性裸交A片一区二区三区| 91成人在线观看视频| 9420在线观看免费播放1| 伊在人亚洲香蕉精品播放| 稚嫩h女娃h粗大小说| fuli.su黑料正能量入口| 爽死你个放荡粗暴小淫货的视频| 97插插插| 快穿c各种受肉大总攻H| 八戒,八戒电影在线看免费动漫| 菲律宾巜丰满的欲妇| 亚洲一区二区三区在线观看| 国产福利片在线易阳| 欧美成人午夜视频在线观看| 国产精品久久碰碰现在自在拍| 国产chinesegay蓝男色| 久久偷看各类wc女厕精品| 亚洲色婷婷综合久久一区二区三区 | 无人码人妻一区二区三区免费| 亚洲a成人7777777久久| 女人麻批日起舒服| 国产精品视频播放| 另类圣水喝尿调教| 欧美日韩国产一区二区三区在线| 黄色3级视频| 一二三四手机高清在线观看视频| 朝鲜一级高潮A片完整片| 精品国产第一区二区三区的应用特点 | 丰满人妻一?A片免费| 粉嫩小泬BBBB免费看按摩| 日本黄色片www| 亚洲国产精品日韩高清秒播| 黄色网址国产| 曰本xxⅹ性| 啊灬啊灬啊灬快灬深用力一级| 美女脱裤子露出稳私视频| 巜人妻侵犯波多野结衣2演员表| 国产人獸交一区二区|