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

MySQL慢查詢優(yōu)化解決問題

 更新時(shí)間:2022年03月16日 10:55:31   作者:@sonny-zhang  
這篇文章主要介紹了MySQL慢查詢優(yōu)化解決問題,MySQL的慢查詢,全名是慢查詢?nèi)罩?,是MySQL提供的一種日志記錄,用來記錄在MySQL中響應(yīng)時(shí)間超過閥值的語句,下文詳細(xì)介紹慢查詢的調(diào)優(yōu)情況,需要的小伙伴可以參考一下

1.  MySQL慢查詢介紹

  MySQL的慢查詢?nèi)罩臼荕ySQL提供的一種日志記錄,它用來記錄在MySQL中響應(yīng)時(shí)間超過閥值的語句,具體指運(yùn)行時(shí)間超過long_query_time值的SQL,則會(huì)被記錄到慢查詢?nèi)罩局?。long_query_time的默認(rèn)值為10,意思是運(yùn)行10S以上的語句。默認(rèn)情況下,Mysql數(shù)據(jù)庫并不啟動(dòng)慢查詢?nèi)罩?,需要我們手?dòng)來設(shè)置這個(gè)參數(shù),當(dāng)然,如果不是調(diào)優(yōu)需要的話,一般不建議啟動(dòng)該參數(shù),因?yàn)殚_啟慢查詢?nèi)罩緯?huì)或多或少帶來一定的性能影響。慢查詢?nèi)罩局С謱⑷罩居涗泴懭胛募仓С謱⑷罩居涗泴懭霐?shù)據(jù)庫表

慢查詢?nèi)罩鞠嚓P(guān)參數(shù):

MySQL 慢查詢的相關(guān)參數(shù)解釋:

  • slow_query_log    :是否開啟慢查詢?nèi)罩荆?表示開啟,0表示關(guān)閉。
  • log-slow-queries  :舊版(5.6以下版本)MySQL數(shù)據(jù)庫慢查詢?nèi)罩敬鎯?chǔ)路徑。可以不設(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.log
  • slow-query-log-file:新版(5.6及以上版本)MySQL數(shù)據(jù)庫慢查詢?nèi)罩敬鎯?chǔ)路徑??梢圆辉O(shè)置該參數(shù),系統(tǒng)則會(huì)默認(rèn)給一個(gè)缺省的文件host_name-slow.log
  • long_query_time :慢查詢閾值,當(dāng)查詢時(shí)間多于設(shè)定的閾值時(shí),記錄日志。
  • log_queries_not_using_indexes:未使用索引的查詢也被記錄到慢查詢?nèi)罩局校蛇x項(xiàng))。
  • log_output:日志存儲(chǔ)方式。log_output='FILE'表示將日志存入文件,默認(rèn)值是'FILE'。log_output='TABLE'表示將日志存入數(shù)據(jù)庫,這樣日志信息就會(huì)被寫入到mysql.slow_log表中。MySQL數(shù)據(jù)庫支持同時(shí)兩種日志存儲(chǔ)方式,配置的時(shí)候以逗號(hào)隔開即可,如:log_output='FILE,TABLE'。日志記錄到系統(tǒng)的專用日志表中,要比記錄到文件耗費(fèi)更多的系統(tǒng)資源,因此對(duì)于需要啟用慢查詢?nèi)罩?,又需要能夠獲得更高的系統(tǒng)性能,那么建議優(yōu)先記錄到文件。

2.發(fā)現(xiàn)問題(主動(dòng)/被動(dòng))

問題點(diǎn):數(shù)據(jù)庫查詢過程中速度過慢的SQL語句

主動(dòng):數(shù)據(jù)庫默認(rèn)情況下slow_query_log的值為OFF,表示慢查詢?nèi)罩臼墙玫?/p>

mysql> show variables ?like '%slow_query_log%';
+---------------------+-----------------------------------------------+
| Variable_name ? ? ? | Value ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+---------------------+-----------------------------------------------+
| slow_query_log ? ? ?| OFF ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
| slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |
+---------------------+-----------------------------------------------+
2 rows in set (0.00 sec)
?
mysql> set global slow_query_log=1;
Query OK, 0 rows affected (0.09 sec)
?
mysql> show variables like '%slow_query_log%';
+---------------------+-----------------------------------------------+
| Variable_name ? ? ? | Value ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |
+---------------------+-----------------------------------------------+
| slow_query_log ? ? ?| ON ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?|
| slow_query_log_file | /home/WDPM/MysqlData/mysql/DB-Server-slow.log |
+---------------------+-----------------------------------------------+
2 rows in set (0.00 sec)

被動(dòng):用戶在使用程序時(shí)候告知頁面反應(yīng)慢

3.找到原因-對(duì)癥下藥

原因點(diǎn):沒有加索引、索引失效、SQL極度復(fù)雜、高并發(fā)

1.表結(jié)構(gòu)設(shè)計(jì)時(shí)沒有索引導(dǎo)致

2.SQL語句導(dǎo)致索引失效

索引失效7字口訣:

  • 模:模糊查詢LIKE以%開頭
  • 型:數(shù)據(jù)類型錯(cuò)誤
  • 數(shù):對(duì)索引字段使用內(nèi)部函數(shù)
  • 空:索引列是NULL
  • 運(yùn):索引列進(jìn)行四則運(yùn)算
  • 最:復(fù)合索引不按索引列最左開始查找
  • 快:全表查找預(yù)計(jì)比索引更快

3.SQL極度復(fù)雜10張以上表聯(lián)合查詢

  • 優(yōu)化表結(jié)構(gòu)和程序

4.高并發(fā)時(shí)段導(dǎo)致等待

  • 在程序和數(shù)據(jù)庫之間加入緩存

Hole yor life get everything if you never give up.

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

相關(guān)文章

  • MySQL數(shù)據(jù)庫之表的約束圖文詳解

    MySQL數(shù)據(jù)庫之表的約束圖文詳解

    在數(shù)據(jù)庫設(shè)計(jì)中,表約束是保證數(shù)據(jù)完整性、一致性的重要手段,數(shù)據(jù)類型本身就是一種基本約束,限制了數(shù)據(jù)的范圍和格式,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • 解決mysql登錄錯(cuò)誤:''Access denied for user ''root''@''localhost''

    解決mysql登錄錯(cuò)誤:''Access denied for user ''root''@''localhost''

    這篇文章主要介紹了mysql登錄錯(cuò)誤:'Access denied for user 'root'@'localhost',本文給出了操作過程及注意事項(xiàng),需要的朋友可以參考下
    2019-11-11
  • Mysql分片,大數(shù)據(jù)量時(shí)擴(kuò)容解決方案

    Mysql分片,大數(shù)據(jù)量時(shí)擴(kuò)容解決方案

    這篇文章主要介紹了Mysql分片,大數(shù)據(jù)量時(shí)擴(kuò)容解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Table ‘xxx’ is marked as crashed and should be repaired 錯(cuò)誤解決方法參考

    Table ‘xxx’ is marked as crashed and should be repaired 錯(cuò)誤解決

    這些東西都是從其他地方找來的一些解決MYSQL數(shù)據(jù)庫這個(gè)錯(cuò)誤的方法,并不一定適用于神跡數(shù)據(jù)庫,僅僅供參考一下,具體的解決方法還是需要摸索。
    2009-04-04
  • Red?Hat?安裝MySQL?8.0與?Navicat的詳細(xì)過程

    Red?Hat?安裝MySQL?8.0與?Navicat的詳細(xì)過程

    這篇文章主要介紹了Red?Hat安裝MySQL8.0與Navicat,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-08-08
  • MySql批量刪除多個(gè)表的方法

    MySql批量刪除多個(gè)表的方法

    本文主要介紹了MySql批量刪除多個(gè)表的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • Mysql 5.7.17忘記密碼怎么辦

    Mysql 5.7.17忘記密碼怎么辦

    這篇文章主要介紹了Mysql 5.7.17忘記密碼的解決方法,需要的朋友可以參考下
    2017-03-03
  • MySQL安裝時(shí)initializing database失敗的問題解決

    MySQL安裝時(shí)initializing database失敗的問題解決

    本文主要介紹了MySQL安裝時(shí)initializing database失敗的問題解決,文中通過圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-02-02
  • MYSQL5 masterslave數(shù)據(jù)同步配置方法

    MYSQL5 masterslave數(shù)據(jù)同步配置方法

    因線路或安全需要我們不得不考慮mysql的備份,特把mysql數(shù)據(jù)備份的方法整理下。
    2008-09-09
  • Mysql數(shù)據(jù)庫中數(shù)據(jù)的操作CRUD詳解

    Mysql數(shù)據(jù)庫中數(shù)據(jù)的操作CRUD詳解

    這篇文章主要介紹了Mysql數(shù)據(jù)庫中數(shù)據(jù)的操作(CRUD),詳細(xì)描述對(duì)Mysql數(shù)據(jù)庫中數(shù)據(jù)的操作(CRUD),包括插入、修改、刪除數(shù)據(jù),還有查詢數(shù)據(jù),包括where、in、like、ifnull、與或非、order by、聚集函數(shù)等,需要的朋友可以參考下
    2025-05-05

最新評(píng)論