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

MySQL優(yōu)化教程之慢查詢(xún)?nèi)罩緦?shí)踐

 更新時(shí)間:2022年06月09日 16:18:57   作者:BugMaker-shen  
在MySQL中慢查詢(xún)?nèi)罩局饕脕?lái)記錄響應(yīng)時(shí)間超過(guò)閾值的SQL,下面這篇文章主要給大家介紹了關(guān)于MySQL優(yōu)化教程之慢查詢(xún)?nèi)罩镜南嚓P(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、慢查詢(xún)?nèi)罩靖拍?/h2>

對(duì)于SQL和索引的優(yōu)化問(wèn)題,我們會(huì)使用explain去分析SQL語(yǔ)句。但是真正的企業(yè)級(jí)項(xiàng)目有成千上萬(wàn)條SQL,我們不可能從頭開(kāi)始一條一條explain去分析。我們從什么地方可以獲取那些運(yùn)行時(shí)間長(zhǎng),耗性能的SQL??

我們可以打開(kāi)慢查詢(xún)?nèi)罩?/strong>:

根據(jù)具體的業(yè)務(wù)和并發(fā)量來(lái)預(yù)估一個(gè)時(shí)間上限(20ms、100ms),設(shè)置好后開(kāi)啟業(yè)務(wù),壓測(cè)后打開(kāi)慢查詢(xún)?nèi)罩?,就?huì)看到超過(guò)執(zhí)行時(shí)間的SQL,然后使用explain分析這些耗時(shí)的SQL語(yǔ)句

步驟如下:

  • 打開(kāi)慢查詢(xún)?nèi)罩鹃_(kāi)關(guān)slow_query_log
  • 設(shè)置合理的、業(yè)務(wù)可以接受的慢查詢(xún)時(shí)間上限
  • 壓測(cè)執(zhí)行各種業(yè)務(wù)
  • 查看慢查詢(xún)?nèi)罩荆页鏊袌?zhí)行耗時(shí)的SQL語(yǔ)句
  • 用explain分析這些耗時(shí)的SQL語(yǔ)句,從而針對(duì)性?xún)?yōu)化

MySQL可以設(shè)置慢查詢(xún)?nèi)罩?,?dāng)SQL執(zhí)行的時(shí)間超過(guò)我們?cè)O(shè)定的時(shí)間,那么這些SQL就會(huì)被記錄在慢查詢(xún)?nèi)罩井?dāng)中,然后我們通過(guò)查看日志,用explain分析這些SQL的執(zhí)行計(jì)劃,來(lái)判定為什么效率低下,是沒(méi)有使用到索引?還是索引本身創(chuàng)建的有問(wèn)題?或者是索引使用到了,但是由于表的數(shù)據(jù)量太大,花費(fèi)的時(shí)間就是很長(zhǎng),那么此時(shí)我們可以把表分成多個(gè)小表等。

慢查詢(xún)?nèi)罩鞠嚓P(guān)的參數(shù)如下所示:

(MySQL定義的很多的全局的開(kāi)關(guān),都是在全局變量中存儲(chǔ),可以用show/set variables查看或者設(shè)置全局變量的值)

慢查詢(xún)?nèi)罩鹃_(kāi)關(guān)默認(rèn)是關(guān)閉的

慢查詢(xún)?nèi)罩镜穆窂剑耗J(rèn)在/var/lib/mysql/

慢查詢(xún)?nèi)罩居涗浟税袌?zhí)行時(shí)間超過(guò)參數(shù) long_query_time(單位:秒)所設(shè)置值的 SQL語(yǔ)句的日志,在MySQL上用命令可以查看,如下:

這個(gè)值是可以修改的:

二、慢查詢(xún)?nèi)罩緦?shí)踐

1. 打開(kāi)慢查詢(xún)?nèi)罩鹃_(kāi)關(guān)slow_query_log

在打開(kāi)慢查詢(xún)?nèi)罩鹃_(kāi)關(guān)的時(shí)候,報(bào)錯(cuò)表示slow_query_log是一個(gè)global的變量(也有只影響當(dāng)前session的變量,如:long_query_time 、profiling),修改后會(huì)影響所有的session,即影響所有正在訪(fǎng)問(wèn)當(dāng)前MySQL server的客戶(hù)端。

打開(kāi)慢查詢(xún)?nèi)罩鹃_(kāi)關(guān)成功!

2. 設(shè)置合理的、業(yè)務(wù)可以接受的慢查詢(xún)時(shí)間上限long_query_time

查看另一個(gè)session

發(fā)現(xiàn)還是默認(rèn)的10s,故long_query_time只影響當(dāng)前session

3. 壓測(cè)執(zhí)行各種業(yè)務(wù)

已經(jīng)超過(guò)我們?cè)O(shè)置的long_query_time=0.1s

4. 查看慢查詢(xún)?nèi)罩?/h3>

路徑:/var/lib/mysql/

5. 用explain分析這些耗時(shí)的SQL語(yǔ)句,從而針對(duì)性?xún)?yōu)化

做了整表的搜索,把主鍵索引樹(shù)整個(gè)掃了一遍。

我們應(yīng)該給password添加索引,然后記得password是字符串格式,因?yàn)槿绻婕邦?lèi)型轉(zhuǎn)換是用不了索引的

三、show profiles查看sql具體的運(yùn)行時(shí)間

MySQL一般只顯示小數(shù)點(diǎn)后兩位的時(shí)間

打開(kāi)profiling開(kāi)關(guān),顯示更詳細(xì)的時(shí)間

沒(méi)有報(bào)錯(cuò),說(shuō)明profiling變量只影響當(dāng)前session

總結(jié) 

到此這篇關(guān)于MySQL優(yōu)化教程之慢查詢(xún)?nèi)罩镜奈恼戮徒榻B到這了,更多相關(guān)MySQL慢查詢(xún)?nèi)罩緝?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入了解mysql長(zhǎng)事務(wù)

    深入了解mysql長(zhǎng)事務(wù)

    這篇文章主要介紹了mysql長(zhǎng)事務(wù)的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下
    2020-08-08
  • Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯(cuò) type=InnDB

    Hibernate4在MySQL5.1以上版本創(chuàng)建表出錯(cuò) type=InnDB

    本文主要介紹解決Hibernate4在MySQL5.1自動(dòng)創(chuàng)建表出錯(cuò)的方法,簡(jiǎn)單實(shí)用,需要的朋友可以參考下。
    2016-05-05
  • Can't connect to MySQL server on localhost (10061)解決方法

    Can't connect to MySQL server 

    今天在安裝mysql后使用mysql命令連接mysql時(shí)報(bào)錯(cuò)?Can't connect to MySQL server on localhost (10061),一般是因?yàn)閙ysql服務(wù)沒(méi)有啟動(dòng)或者用戶(hù)名密碼不正確
    2011-03-03
  • 解析mysql不重復(fù)字段值求和

    解析mysql不重復(fù)字段值求和

    本篇文章是對(duì)關(guān)于mysql不重復(fù)字段值求和進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • 圖文詳解mysql中with...as用法

    圖文詳解mysql中with...as用法

    這篇文章主要給大家介紹了關(guān)于mysql中with...as用法的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用mysql具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-01-01
  • windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法

    windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法

    這篇文章給大家介紹了windows server2014 安裝 Mysql Applying Security出錯(cuò)的完美解決方法,造成這種問(wèn)題的主要原因是因?yàn)榘惭b一遍之后沒(méi)有卸載干凈,要解決這個(gè)問(wèn)題需要注意以下幾點(diǎn),具體解決方法,大家參考下本文
    2017-07-07
  • SQL LIKE運(yùn)算符用法示例及通配符解釋

    SQL LIKE運(yùn)算符用法示例及通配符解釋

    這篇文章主要為大家介紹了SQL LIKE運(yùn)算符用法示例及通配符解釋,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11
  • MySQL Truncate用法詳解

    MySQL Truncate用法詳解

    這篇文章主要介紹了MySQL Truncate用法的相關(guān)資料,幫助大家更好的理解和使用MySQL,感興趣的朋友可以了解下
    2020-08-08
  • 解決找回mysql數(shù)據(jù)庫(kù)密碼和密碼過(guò)期問(wèn)題

    解決找回mysql數(shù)據(jù)庫(kù)密碼和密碼過(guò)期問(wèn)題

    這篇文章主要介紹了解決找回mysql數(shù)據(jù)庫(kù)密碼和密碼過(guò)期問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Mysql5.5安裝配置方法及中文亂碼的快速解決方法

    Mysql5.5安裝配置方法及中文亂碼的快速解決方法

    這篇文章主要介紹了Mysql5.5安裝配置方法以及mysql5.5中文亂碼的快速解決方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-08-08

最新評(píng)論