校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 必備 SQL 查詢優化技巧提升網站訪問速度

必備 SQL 查詢優化技巧提升網站訪問速度

熱門標簽:千呼電銷機器人價格 智能語音外呼系統選哪家 優質地圖標注 怎樣在地圖上標注路線圖標 武漢長沙外呼系統方法和技巧 京華物流公司地圖標注 百度地圖標注不同路線 外呼系統電銷專用 奧威地圖標注多個地方

在這篇文章中,我將介紹如何識別導致性能出現問題的查詢,如何找出它們的問題所在,以及快速修復這些問題和其他加快查詢速度的方法。

你一定知道,一個快速訪問的網站能讓用戶喜歡,可以幫助網站從Google 上提高排名,可以幫助網站增加轉化率。如果你看過網站性能優化方面的文章,例如設置服務器的最佳實現、到干掉慢速代碼以及 使用CDN 加載圖片,就認為你的 WordPress 網站已經足夠快了。但是事實果真如此嗎?

使用動態數據庫驅動的網站,例如WordPress,你的網站可能依然有一個問題亟待解決:數據庫查詢拖慢了網站訪問速度。

在這篇文章中,我將介紹如何識別導致性能出現問題的查詢,如何找出它們的問題所在,以及快速修復這些問題和其他加快查詢速度的方法。我會把門戶網站 deliciousbrains.com 出現的拖慢查詢速度的情況作為實際的案例。

定位

處理慢SQL查詢的第一步是找到慢查詢。Ashley已經在之前的博客里面贊揚了調試插件Query Monitor,而且這個插件的數據庫查詢特性使其成為定位慢SQL查詢的寶貴工具。

該插件會報告所有頁面請求過程中的數據庫請求,并且可以通過調用這些查詢代碼或者原件(插件,主題,WordPress核)過濾這些查詢,高亮重復查詢和慢查詢。

要是不愿意在生產安環境裝調試插件(性能開銷原因),也可以打開MySQL Slow Query Log,這樣在特定時間執行的所有查詢都會被記錄下來。這種方法配置和設置存放查詢位置相對簡單。

由于這是一個服務級別的調整,性能影響會小于使用調試插件,但當不用的時候也應該關閉。

理解

一旦你找到了一個你要花很大代價找到的查詢,那么接下來就是嘗試去理解它并找到是什么讓查詢變慢。最近,在我們開發我們網站的時候,我們找到了一個要執行8秒的查詢。

我們使用WooCommerce和定制版的WooCommerce軟件插件來運行我們的插件商店。此查詢的目的是獲取那些我們知道客戶號的客戶的所有訂閱。

WooCommerce是一個稍微復雜的數據模型,即使訂單以自定義的類型存儲,用戶的ID(商店為每一個用戶創建的WordPress)也沒有存儲在post_author,而是作為后期數據的一部分。訂閱軟件插件給自義定表創建了一對鏈接。讓我們深入了解查詢的更多信息。

把 MySQL 當作朋友

MySQL有一個很方便的語句DESCRIBE,它可以輸出表結構的信息,比如字段名,數據類型等等。所以,當你執行DESCRIBE wp_postmeta;你將會看到如下的結果:

你可能已經知道了這個語句。但是你知道DESCRIBE語句可以放在SELECT, INSERT, UPDATE, REPLACE 和 DELETE語句前邊使用嗎?更為人們所熟知的是他的同義詞 EXPLAIN ,并將提供有關該語句如何執行的詳細信息。

這是我們查詢到的結果:

乍一看,這很難解釋。幸運的是,人們通過SitePoint總結了一個理解語句的全面指南。

最重要的字段是type,它描述了一張表是怎么構成的。

如果你想看全部的內容,那就意味著MySQL要從內存讀取整張表,增加I/O的速度并在CPU上加載。這種被稱為“全表瀏覽”—稍后將對此進行詳細介紹。

rows字段也是一個好的標識,標識著MySQL將要不得不做的事情,它顯示了結果中查找了多少行。

Explain也給了我們很多可以優化的信息。例如,pm2表((wp_postmeta),告訴我們是Using filesort,因為我們使用了 ORDER BY語句對結果進行了排序。如果我們要對查詢結果進行分組,這將會給執行增加開銷。

可視化研究

對于這種類型的研究,MySQL Workbench是另外一個方便,免費的工具。將數據庫用MySQL5.6及其以上的版本打開,EXPLAIN的結果可以用JSON格式輸出,同時MySQL Workbench將JSON轉換成可視化執行語句:

它自動將查詢的問題用顏色著重表示提醒用戶去注意。我們可以馬上看到,連接wp_woocommerce_software_licences(別名l)的表有嚴重的問題。

解決

你應該避免(https://dev.mysql.com/doc/refman/5.7/en/table-scan-avoidance.html)這種全部表瀏覽的查詢,因為他使用非索引字段order_id去連接wp_woocommerce_software_licences表和wp_posts表。這對于查詢慢是常見的問題,而且也是比較容易解決的問題。

索引

order_id在表中是一個相當重要的標志性數據,如果想像這種方式查詢,我們需要在列上建立一個索引,除此之外,MySQL將逐字掃描表的每一行,直到找到我們想要的行為止。讓我們添加一個索引并看看它是怎么樣工作的:

哇,干的漂亮!我們成功的添加了索引并將查詢的時間縮短了5s.

了解你的查詢語句

檢查下查詢語句——看看每一個join,每一個子查詢。它們做了它們不該做的事了嗎?這里能做什么優化嗎?

這個例子中,我們把licenses 表和posts 表通過order_id 連接起來同時限制post type 為shop_order。這是為了通過保持數據的完整性來保證我們只使用正確的訂單記錄,但是事實上這在查詢中是多余的。

我們知道這是一個關于安全的賭注,在posts 表中software license 行是通過order_id 來跟 WooCommerce order 相關聯的,這在PHP 插件代碼中是強制的。讓我們移除join 來看看有什么提升沒有:

 

提升并不算很大但現在查詢時間低于3 秒了。

緩存所有數據

如果你的服務器默認情況下沒有使用MySQL查詢緩存,那么你應該開啟緩存。

開啟緩存意味著MySQL 會把所有的語句和語句執行的結果保存下來,如果隨后有一條與緩存中完全相同的語句需要執行,那么MySQL 就會返回緩存的結果。緩存不會過時,因為MySQL 會在表數據更新后刷新緩存。

查詢監視器發現在加載一個頁面時我們的查詢語句執行了四次,盡管有MySQL查詢緩存很好,但是在一個請求中重復讀取數據庫的數據是應該完全避免的。

你的PHP 代碼中的靜態緩存很簡單并且可以很高效的解決這個問題。基本上,首次請求時從數據庫中獲取查詢結果,并將其存儲在類的靜態屬性中,然后后續的查詢語句調用將從靜態屬性中返回結果:

緩存有一個生命周期,具體地說是實例化對象有一個生命周期。如果你正在查看跨請求的查詢結果,那么你需要實現一個持久對象緩存。然而不管怎樣,你的代碼應該負責設置緩存,并且當基礎數據變更時讓緩存失效。

換位思考

不僅僅是調整查詢或添加索引,還有其他方法可以加快查詢的執行速度。 我們查詢的最慢的部分是從客戶ID到產品ID再到加入表格所做的工作,我們必須為每個客戶做到。

我們是不是可以在需要的時候抓取客戶的數據?如果是那樣,那我們就只需要加入一次。

您可以通過創建數據表來存儲許可數據,以及所有許可用戶標識和產品標識符來對數據進行非規范化(反規范化)處理,并針對特定客戶進行查詢。

您需要使用INSERT / UPDATE / DELETE上的MySQL觸發器來重建表格(不過這要取決于數據來更改的表格),這會顯著提高查詢數據的性能。

類似地,如果一些連接在MySQL中減慢了查詢速度,那么將查詢分解為兩個或更多語句并在PHP中單獨執行它們可能會更快,然后可以在代碼中收集和過濾結果。 Laravel 通過預加載在 Eloquent 中就做了類似的事情。

如果您有大量數據和許多不同的自定義帖子類型,WordPress可能會在wp_posts表上減慢查詢速度。 如果您發現查詢的帖子類型較慢,那么可以考慮從自定義帖子類型的存儲模型移動到自定義表格中 - 更多內容將在后面的文章中介紹。

結論

通過這些查詢優化方法,我們設法將查詢從8秒降低到2秒,并且將查詢次數從4次減少到1次。需要說明的是,這些查詢時間是在我們開發環境運行時記錄的 ,生產環境速度會更快。

這對追蹤查詢緩慢及其修復等問題是一個有用的指南。 優化查詢看起來可能像一個可怕的任務,但只要你嘗試一下,并取得一些初步的勝利,你就會開始找到錯誤,并希望做出進一步改善。

您可能感興趣的文章:
  • 淺談MySQL中的子查詢優化技巧
  • php+mysql查詢優化簡單實例
  • MySQL查詢優化之explain的深入解析
  • MySQL查詢優化--調整內部變量的詳解
  • MySQL查詢優化:連接查詢排序limit(join、order by、limit語句)介紹
  • MySQL查詢優化:LIMIT 1避免全表掃描提高查詢效率
  • MySQL查詢優化:用子查詢代替非主鍵連接查詢實例介紹

標簽:來賓 七臺河 宿州 銅仁 防疫戰設 天水 威海 益陽

巨人網絡通訊聲明:本文標題《必備 SQL 查詢優化技巧提升網站訪問速度》,本文關鍵詞  必備,SQL,查詢,優化,技巧,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《必備 SQL 查詢優化技巧提升網站訪問速度》相關的同類信息!
  • 本頁收集關于必備 SQL 查詢優化技巧提升網站訪問速度的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    91欧美激情一区二区三区成人| 久久精品久久99精品久久| 精品国产一区二区三区av性色| 91麻豆蜜桃一区二区三区| 成人av免费观看| a级精品国产片在线观看| 成人免费三级在线| 成人涩涩免费视频| 99久久精品国产网站| 91在线视频观看| 欧美视频在线观看一区二区| 欧美三级日韩三级国产三级| 欧美丰满一区二区免费视频| 欧美久久免费观看| 精品国产免费人成在线观看| 久久亚洲影视婷婷| 综合中文字幕亚洲| 亚洲午夜免费视频| 老色鬼精品视频在线观看播放| 久久成人免费网站| www.日本不卡| 欧美日韩一二三区| 久久综合久久综合九色| 日本一区二区视频在线观看| ...av二区三区久久精品| 综合在线观看色| 日韩精品一二三| 国产精品一区二区无线| av综合在线播放| 日韩一区二区三区观看| 久久女同互慰一区二区三区| 日韩理论在线观看| 老司机午夜精品| 91猫先生在线| 久久久亚洲高清| 亚洲第一二三四区| 丰满放荡岳乱妇91ww| 欧美午夜精品久久久久久孕妇| 精品久久久久久综合日本欧美| 中文字幕日韩一区二区| 亚洲超丰满肉感bbw| 国产精品一级片| 欧美日韩免费在线视频| 国产欧美一区二区三区沐欲| 亚洲国产精品人人做人人爽| 国产乱码精品一区二区三区五月婷| 91丨九色丨蝌蚪丨老版| 26uuu亚洲综合色欧美 | 老鸭窝一区二区久久精品| 国产精品中文字幕欧美| 欧美浪妇xxxx高跟鞋交| 亚洲欧美在线视频| 久久99久久久久| 在线观看一区日韩| 国产精品国产三级国产aⅴ无密码| 免费成人在线播放| 欧美色综合网站| 亚洲免费观看在线视频| 国产精品一区二区男女羞羞无遮挡| 欧美日韩综合在线免费观看| 亚洲欧洲日本在线| 高清久久久久久| 久久久亚洲综合| 美美哒免费高清在线观看视频一区二区 | 亚洲免费观看高清| 成人在线视频一区| 国产亚洲欧美一区在线观看| 久久精品国产第一区二区三区| 欧美无乱码久久久免费午夜一区| 一区二区三区精品视频| 不卡的av电影在线观看| 日本一区二区三区免费乱视频| 蜜桃精品在线观看| 日韩久久精品一区| 久久成人免费网| 久久蜜桃av一区精品变态类天堂 | 六月丁香综合在线视频| 欧美图区在线视频| 亚洲国产一区视频| 日本韩国一区二区| 亚洲一区二区av在线| 欧洲一区二区av| 夜夜嗨av一区二区三区网页| 欧美中文字幕一区| 一区二区三区精品在线观看| 色婷婷综合激情| 丝袜美腿亚洲色图| 欧美一级片免费看| 国产麻豆9l精品三级站| 久久久激情视频| 成人激情午夜影院| 亚洲欧美乱综合| 69p69国产精品| 极品美女销魂一区二区三区 | 国产精品资源在线看| 久久免费午夜影院| www.性欧美| 亚洲成人动漫在线观看| 日韩一本二本av| 成人一区二区三区| 亚洲一二三四久久| 日韩一级在线观看| 成人性生交大片免费看视频在线| 国产精品电影一区二区| 欧美精品丝袜中出| 国产乱码精品1区2区3区| 亚洲精品日日夜夜| 日韩欧美成人午夜| 91视频在线看| 日韩av中文在线观看| 国产精品卡一卡二| 4438成人网| 99天天综合性| 精品一区二区在线观看| 亚洲欧美乱综合| 久久网这里都是精品| 日本高清成人免费播放| 精品一区二区三区久久| 亚洲激情第一区| 日本一区二区三区在线不卡| 欧美日韩国产另类一区| 成人黄色片在线观看| 琪琪一区二区三区| 亚洲精品国产精品乱码不99| 精品欧美一区二区在线观看 | 日韩二区三区四区| 欧美韩国日本综合| 欧美一区二区久久久| gogo大胆日本视频一区| 国产美女视频91| 日本午夜精品视频在线观看 | 久久夜色精品一区| 欧美日韩国产美女| 色中色一区二区| 国产精品一区二区无线| 免费日韩伦理电影| 亚洲一区在线观看免费观看电影高清| 久久久久久影视| 日韩欧美一区电影| 欧美日韩三级一区二区| 色婷婷综合久色| 99精品一区二区| 粉嫩一区二区三区在线看| 精品一区二区三区免费毛片爱| 亚洲不卡一区二区三区| 亚洲不卡一区二区三区| 艳妇臀荡乳欲伦亚洲一区| 亚洲少妇最新在线视频| 国产精品视频一二三区| 国产精品色眯眯| 国产精品久久久久影院| 亚洲国产精品高清| 亚洲欧美自拍偷拍| 伊人夜夜躁av伊人久久| 亚洲精选一二三| 亚洲午夜久久久久久久久久久| 一区二区高清在线| 亚洲愉拍自拍另类高清精品| 一区二区三区在线观看动漫| 亚洲免费av高清| 亚洲一区成人在线| 亚洲一区二区三区爽爽爽爽爽| 亚洲午夜羞羞片| 肉色丝袜一区二区| 捆绑调教一区二区三区| 激情av综合网| 成人av网站在线观看免费| 91美女在线看| 欧美精品三级日韩久久| 91精品久久久久久久99蜜桃| 国产午夜亚洲精品午夜鲁丝片| 久久精品欧美日韩精品| 中文字幕在线不卡国产视频| 亚洲精品水蜜桃| 日韩av电影免费观看高清完整版 | 成人精品国产免费网站| 一本到一区二区三区| 欧美麻豆精品久久久久久| 欧美成人国产一区二区| 国产午夜精品福利| 一区二区三区中文字幕电影 | 综合久久给合久久狠狠狠97色| 亚洲理论在线观看| 久久99精品一区二区三区| av在线播放一区二区三区| 色综合久久久久综合体桃花网| 69久久99精品久久久久婷婷| 国产欧美综合色| 五月婷婷激情综合| 成人爽a毛片一区二区免费| 欧美三级电影精品| 国产免费成人在线视频| 一区二区高清免费观看影视大全 | 成人性生交大片免费看视频在线| 色88888久久久久久影院按摩| 精品国产伦一区二区三区观看体验| 亚洲欧美日韩精品久久久久| 蜜桃av一区二区三区电影| 91在线一区二区三区| 久久综合久久鬼色|