亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL數(shù)據(jù)庫查詢性能優(yōu)化的4個技巧干貨

 更新時間:2022年08月01日 15:13:28   作者:IT學(xué)習(xí)日記v  
這篇文章主要為大家介紹了MySQL數(shù)據(jù)庫查詢性能優(yōu)化的4個技巧干貨詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

前言

MySQL性能優(yōu)化是一個老生常談的問題,無論是在實際工作中還是面試中,都不可避免遇到相應(yīng)的場景,下面博主就總結(jié)一些能夠幫助大家解決這個問題的小技巧。

SQL優(yōu)化之前需要確認(rèn)哪些SQL需要優(yōu)化,這時就需要引起SQL性能分析工具,主要優(yōu)化的是查詢語句。

SQL的執(zhí)行頻率

SQL性能優(yōu)化一般是針對查詢語句,所以在定位是否需要優(yōu)化之前,可以先確認(rèn)表的更刪查改的一個執(zhí)行頻率對比,如果是查詢占主導(dǎo)地位,則可以一步排查。

MySQL支持客戶端通過show [session|global] status命令對服務(wù)器狀態(tài)進(jìn)行查詢。

查看執(zhí)行頻率方式:

show global status like ‘com_______’(7個下劃線,表示后面會有7個字符)

慢查詢?nèi)罩?/h2>

確認(rèn)了SQL的執(zhí)行頻率,則需要通過慢查詢?nèi)罩具M(jìn)行進(jìn)一步定位哪些SQL語句執(zhí)行時間占用較長。

慢查詢?nèi)罩居涗浟怂袌?zhí)行時間超過指定參數(shù)(long_query_time,單位:秒,默認(rèn)是10s)的所有SQL語句的日志。

默認(rèn)情況下,慢查詢?nèi)罩臼菦]有開啟的,需要在MySQL的配置文件(linux下為:/etc/my.cnf)中配置如下指令:

  • 查詢服務(wù)端是否開啟慢查詢?nèi)罩荆簊how variables like 'slow_query_log';
  • 在mysql的配置文件中添加如下配置啟動:
  • slow_query_log=1;開啟mysql慢日志查詢開關(guān)
  • long_query_time=xx;設(shè)置慢日志時間,只要SQL執(zhí)行時間查過該值,則視為慢查詢,記錄在慢日志中。
  • 配置完成后重啟mysql服務(wù)端
  • linux中mysql的慢日志文件在: /var/lib/mysql/localhost-slow.log

window可以在my.ini文件中配置具體的地址

Query_time SQL執(zhí)行的時間,越長則越慢

Lock_time 在MySQL服務(wù)器階段(不是在存儲引擎階段)等待表鎖時間

Rows_sent 查詢返回的行數(shù)

Rows_examined 查詢檢查的行數(shù)

show profiles詳情分析

通過慢查詢?nèi)罩荆覀兛梢远ㄎ坏匠^設(shè)置閾值的慢SQL,但是實際業(yè)務(wù)中,這并不能完全具有代表性,因為閾值是主觀設(shè)置的,可能有大量執(zhí)行時間低于閾值的SQL也存在問題,因此慢日志SQL并不能完全定位出所有的慢SQL。

show profiles 能夠讓我們了解到SQL執(zhí)行時時間都耗費(fèi)到哪里了。 通過have_profiling參數(shù),可以查看mysql是否支持該profile操作。

格式: select @@have_profiling;

默認(rèn)情況下,profiling是關(guān)閉的,可以同set指令開啟session|global級別的profiling。

格式: set global | session profiling = 1;

優(yōu)化方案:

  • show profiles; 查看每一條SQL的耗時基本情況
  • show profile for query query_id; 查詢指定query_id的SQL語句各個階段的耗時情況
  • show profile cpu for query query_id; 查詢指定query_id的SQL語句cpu使用情況

explain執(zhí)行計劃

前面介紹的幾種方式都是通過執(zhí)行時間長短來判斷SQL語句執(zhí)行的性能好壞,但是這個相對來說是比較片面的,想要更全面地評判SQL語句好壞,則需要使用explain查看SQL的執(zhí)行計劃。

Explain或者DESC命令獲取MySQL如何執(zhí)行SELECT語句的信息,包括在SELECT語句過程中表如何連接和連接的順序。

語法:explain | desc select xxxx...

1、ID參數(shù)

select中的查詢序號,表示的是查詢中執(zhí)行select子句或者是操作表的順序(id相同,執(zhí)行順序從上往下,id不同,值越大,越先執(zhí)行)

2、select_type參數(shù)

表示select查詢類型,常見的有SIMPLE(簡單表,即不使用表連接或者子查詢)、primary(主查詢,即外層查詢)、UNION(UNION中的第二個或者后面的查詢語句)、SUBQUERY(SELECT/WHERE之后包含了子查詢)

3、type參數(shù)

表示連接/訪問類型,性能由好到差的連接類型為:null、system、const、eq_ref、ref、range、index、all

在優(yōu)化的時候,盡量將type往前優(yōu)化,最差也要為index

  • null:查詢的時候不訪問任何表,如:select "1"
  • system:當(dāng)訪問一些系統(tǒng)表的時候會出現(xiàn)
  • const:根據(jù)主鍵或者唯一索引訪問時,會出現(xiàn)const
  • eq_ref:待確認(rèn)
  • ref:使用非唯一性索引進(jìn)行訪問時,可能出現(xiàn)ref
  • range:
  • index:使用到了索引,但是對整個索引都進(jìn)行了遍歷,性能也比較差
  • all:全表掃描,性能最差

4、possible_key參數(shù):顯示在執(zhí)行查詢時,表中可能被使用到的索引,一個或者多個、

5、key參數(shù):在執(zhí)行查詢時,實際上會命中的索引

6、key_len參數(shù):表示使用到的索引的字節(jié)數(shù),該值為索引字段最大可能長度,在不損失精確性的前提下,長度越短越好。

7、rows參數(shù):MySQL認(rèn)為必須要執(zhí)行查詢的行數(shù),在idb引擎表中,是一個估計值,可能并不總是準(zhǔn)確的

8、ref參數(shù):待確認(rèn)?

9、filtered參數(shù):表示查詢返回的行數(shù)占總讀取行數(shù)的百分比,值越大越好

10、extra參數(shù):額外的一些執(zhí)行信息如排序

以上就是MySQL數(shù)據(jù)庫查詢性能優(yōu)化的4個技巧干貨的詳細(xì)內(nèi)容,更多關(guān)于MySQL查詢性能優(yōu)化的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • mysql5.7.23版本安裝教程及配置方法

    mysql5.7.23版本安裝教程及配置方法

    這篇文章主要介紹了mysql5.7.23版本安裝教程及配置方法,需要的朋友可以參考下
    2018-11-11
  • mysql 5.7.11 winx64.zip安裝配置方法圖文教程

    mysql 5.7.11 winx64.zip安裝配置方法圖文教程

    這篇文章主要為大家分享了mysql5.7.11安裝配置方法圖文教程,具有一定的參考價值,感興趣的朋友可以參考一下
    2017-02-02
  • 關(guān)于MySQL中的查詢開銷查看方法詳解

    關(guān)于MySQL中的查詢開銷查看方法詳解

    一個查詢通??梢杂泻芏喾N執(zhí)行方式,并且返回同樣的結(jié)果,而好的程序員應(yīng)該是找到最好的方式,下面這篇文章主要給大家介紹了關(guān)于MySQL中查詢開銷查看方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-07-07
  • MySQL視圖和索引專篇精講

    MySQL視圖和索引專篇精講

    這篇文章主要介紹了MySQL的視圖和索引用法與區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • MySQL8.0中你必須要知道的索引新特性

    MySQL8.0中你必須要知道的索引新特性

    MySQL8.0索引新特性,支持降序索引,降序索引以降序存儲鍵值,下面這篇文章主要給大家介紹了關(guān)于MySQL8.0中你必須要知道的索引新特性的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • Mysql8.0輕松實現(xiàn)主從復(fù)制

    Mysql8.0輕松實現(xiàn)主從復(fù)制

    這篇文章主要介紹了Mysql8.0輕松實現(xiàn)主從復(fù)制方法的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • MySQL數(shù)據(jù)庫21條最佳性能優(yōu)化經(jīng)驗

    MySQL數(shù)據(jù)庫21條最佳性能優(yōu)化經(jīng)驗

    數(shù)據(jù)庫的操作越來越成為整個應(yīng)用的性能瓶頸了,這點對于Web應(yīng)用尤其明顯。這篇文章主要介紹了MySQL數(shù)據(jù)庫21條最佳性能優(yōu)化經(jīng)驗的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • Mysql?刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)(最新推薦)

    Mysql?刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù)(最新推薦)

    這篇文章主要介紹了Mysql?刪除重復(fù)數(shù)據(jù)保留一條有效數(shù)據(jù),實現(xiàn)原理也很簡單,mysql刪除重復(fù)數(shù)據(jù),多個字段分組操作,結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Mysql中文漢字轉(zhuǎn)拼音的實現(xiàn)(每個漢字轉(zhuǎn)換全拼)

    Mysql中文漢字轉(zhuǎn)拼音的實現(xiàn)(每個漢字轉(zhuǎn)換全拼)

    這篇文章主要介紹了Mysql中文漢字轉(zhuǎn)拼音的實現(xiàn),并且每個漢字會轉(zhuǎn)換全拼,使用Mysql自定義函數(shù)實現(xiàn),需要的朋友可以參考下
    2014-06-06
  • Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決

    Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決

    最近忽然發(fā)現(xiàn)個問題,Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致,通過查找相關(guān)資料終于解決了,下面這篇文章主要給大家介紹了關(guān)于Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決的相關(guān)資料,需要的朋友可以參考下
    2023-06-06

最新評論