亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁(yè) > 數(shù)據(jù)庫(kù) > SQL Server > 正文

必備 SQL 查詢優(yōu)化技巧提升網(wǎng)站訪問(wèn)速度

2024-08-31 01:05:15
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

在這篇文章中,我將介紹如何識(shí)別導(dǎo)致性能出現(xiàn)問(wèn)題的查詢,如何找出它們的問(wèn)題所在,以及快速修復(fù)這些問(wèn)題和其他加快查詢速度的方法。

sql,查詢優(yōu)化

你一定知道,一個(gè)快速訪問(wèn)的網(wǎng)站能讓用戶喜歡,可以幫助網(wǎng)站從Google 上提高排名,可以幫助網(wǎng)站增加轉(zhuǎn)化率。如果你看過(guò)網(wǎng)站性能優(yōu)化方面的文章,例如設(shè)置服務(wù)器的最佳實(shí)現(xiàn)、到干掉慢速代碼以及 使用CDN 加載圖片,就認(rèn)為你的 WordPress 網(wǎng)站已經(jīng)足夠快了。但是事實(shí)果真如此嗎?

使用動(dòng)態(tài)數(shù)據(jù)庫(kù)驅(qū)動(dòng)的網(wǎng)站,例如WordPress,你的網(wǎng)站可能依然有一個(gè)問(wèn)題亟待解決:數(shù)據(jù)庫(kù)查詢拖慢了網(wǎng)站訪問(wèn)速度。

在這篇文章中,我將介紹如何識(shí)別導(dǎo)致性能出現(xiàn)問(wèn)題的查詢,如何找出它們的問(wèn)題所在,以及快速修復(fù)這些問(wèn)題和其他加快查詢速度的方法。我會(huì)把門戶網(wǎng)站 deliciousbrains.com 出現(xiàn)的拖慢查詢速度的情況作為實(shí)際的案例。

定位

處理慢SQL查詢的第一步是找到慢查詢。Ashley已經(jīng)在之前的博客里面贊揚(yáng)了調(diào)試插件Query Monitor,而且這個(gè)插件的數(shù)據(jù)庫(kù)查詢特性使其成為定位慢SQL查詢的寶貴工具。

該插件會(huì)報(bào)告所有頁(yè)面請(qǐng)求過(guò)程中的數(shù)據(jù)庫(kù)請(qǐng)求,并且可以通過(guò)調(diào)用這些查詢代碼或者原件(插件,主題,WordPress核)過(guò)濾這些查詢,高亮重復(fù)查詢和慢查詢。

sql,查詢優(yōu)化

要是不愿意在生產(chǎn)安環(huán)境裝調(diào)試插件(性能開(kāi)銷原因),也可以打開(kāi)MySQL Slow Query Log,這樣在特定時(shí)間執(zhí)行的所有查詢都會(huì)被記錄下來(lái)。這種方法配置和設(shè)置存放查詢位置相對(duì)簡(jiǎn)單。

由于這是一個(gè)服務(wù)級(jí)別的調(diào)整,性能影響會(huì)小于使用調(diào)試插件,但當(dāng)不用的時(shí)候也應(yīng)該關(guān)閉。

理解

一旦你找到了一個(gè)你要花很大代價(jià)找到的查詢,那么接下來(lái)就是嘗試去理解它并找到是什么讓查詢變慢。最近,在我們開(kāi)發(fā)我們網(wǎng)站的時(shí)候,我們找到了一個(gè)要執(zhí)行8秒的查詢。

我們使用WooCommerce和定制版的WooCommerce軟件插件來(lái)運(yùn)行我們的插件商店。此查詢的目的是獲取那些我們知道客戶號(hào)的客戶的所有訂閱。

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

把 MySQL 當(dāng)作朋友

MySQL有一個(gè)很方便的語(yǔ)句DESCRIBE,它可以輸出表結(jié)構(gòu)的信息,比如字段名,數(shù)據(jù)類型等等。所以,當(dāng)你執(zhí)行DESCRIBE wp_postmeta;你將會(huì)看到如下的結(jié)果:

sql,查詢優(yōu)化

你可能已經(jīng)知道了這個(gè)語(yǔ)句。但是你知道DESCRIBE語(yǔ)句可以放在SELECT, INSERT, UPDATE, REPLACE 和 DELETE語(yǔ)句前邊使用嗎?更為人們所熟知的是他的同義詞 EXPLAIN ,并將提供有關(guān)該語(yǔ)句如何執(zhí)行的詳細(xì)信息。

這是我們查詢到的結(jié)果:

sql,查詢優(yōu)化

乍一看,這很難解釋。幸運(yùn)的是,人們通過(guò)SitePoint總結(jié)了一個(gè)理解語(yǔ)句的全面指南。

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

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

rows字段也是一個(gè)好的標(biāo)識(shí),標(biāo)識(shí)著MySQL將要不得不做的事情,它顯示了結(jié)果中查找了多少行。

Explain也給了我們很多可以優(yōu)化的信息。例如,pm2表((wp_postmeta),告訴我們是Using filesort,因?yàn)槲覀兪褂昧?ORDER BY語(yǔ)句對(duì)結(jié)果進(jìn)行了排序。如果我們要對(duì)查詢結(jié)果進(jìn)行分組,這將會(huì)給執(zhí)行增加開(kāi)銷。

可視化研究

對(duì)于這種類型的研究,MySQL Workbench是另外一個(gè)方便,免費(fèi)的工具。將數(shù)據(jù)庫(kù)用MySQL5.6及其以上的版本打開(kāi),EXPLAIN的結(jié)果可以用JSON格式輸出,同時(shí)MySQL Workbench將JSON轉(zhuǎn)換成可視化執(zhí)行語(yǔ)句:

sql,查詢優(yōu)化

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

解決

你應(yīng)該避免(https://dev.mysql.com/doc/refman/5.7/en/table-scan-avoidance.html)這種全部表瀏覽的查詢,因?yàn)樗褂梅撬饕侄蝟rder_id去連接wp_woocommerce_software_licences表和wp_posts表。這對(duì)于查詢慢是常見(jiàn)的問(wèn)題,而且也是比較容易解決的問(wèn)題。

索引

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

sql,查詢優(yōu)化

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

了解你的查詢語(yǔ)句

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

這個(gè)例子中,我們把licenses 表和posts 表通過(guò)order_id 連接起來(lái)同時(shí)限制post type 為shop_order。這是為了通過(guò)保持?jǐn)?shù)據(jù)的完整性來(lái)保證我們只使用正確的訂單記錄,但是事實(shí)上這在查詢中是多余的。

我們知道這是一個(gè)關(guān)于安全的賭注,在posts 表中software license 行是通過(guò)order_id 來(lái)跟 WooCommerce order 相關(guān)聯(lián)的,這在PHP 插件代碼中是強(qiáng)制的。讓我們移除join 來(lái)看看有什么提升沒(méi)有:

sql,查詢優(yōu)化

提升并不算很大但現(xiàn)在查詢時(shí)間低于3 秒了。

緩存所有數(shù)據(jù)

如果你的服務(wù)器默認(rèn)情況下沒(méi)有使用MySQL查詢緩存,那么你應(yīng)該開(kāi)啟緩存。

開(kāi)啟緩存意味著MySQL 會(huì)把所有的語(yǔ)句和語(yǔ)句執(zhí)行的結(jié)果保存下來(lái),如果隨后有一條與緩存中完全相同的語(yǔ)句需要執(zhí)行,那么MySQL 就會(huì)返回緩存的結(jié)果。緩存不會(huì)過(guò)時(shí),因?yàn)镸ySQL 會(huì)在表數(shù)據(jù)更新后刷新緩存。

查詢監(jiān)視器發(fā)現(xiàn)在加載一個(gè)頁(yè)面時(shí)我們的查詢語(yǔ)句執(zhí)行了四次,盡管有MySQL查詢緩存很好,但是在一個(gè)請(qǐng)求中重復(fù)讀取數(shù)據(jù)庫(kù)的數(shù)據(jù)是應(yīng)該完全避免的。

你的PHP 代碼中的靜態(tài)緩存很簡(jiǎn)單并且可以很高效的解決這個(gè)問(wèn)題?;旧?,首次請(qǐng)求時(shí)從數(shù)據(jù)庫(kù)中獲取查詢結(jié)果,并將其存儲(chǔ)在類的靜態(tài)屬性中,然后后續(xù)的查詢語(yǔ)句調(diào)用將從靜態(tài)屬性中返回結(jié)果:

sql,查詢優(yōu)化

緩存有一個(gè)生命周期,具體地說(shuō)是實(shí)例化對(duì)象有一個(gè)生命周期。如果你正在查看跨請(qǐng)求的查詢結(jié)果,那么你需要實(shí)現(xiàn)一個(gè)持久對(duì)象緩存。然而不管怎樣,你的代碼應(yīng)該負(fù)責(zé)設(shè)置緩存,并且當(dāng)基礎(chǔ)數(shù)據(jù)變更時(shí)讓緩存失效。

換位思考

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

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

您可以通過(guò)創(chuàng)建數(shù)據(jù)表來(lái)存儲(chǔ)許可數(shù)據(jù),以及所有許可用戶標(biāo)識(shí)和產(chǎn)品標(biāo)識(shí)符來(lái)對(duì)數(shù)據(jù)進(jìn)行非規(guī)范化(反規(guī)范化)處理,并針對(duì)特定客戶進(jìn)行查詢。

您需要使用INSERT / UPDATE / DELETE上的MySQL觸發(fā)器來(lái)重建表格(不過(guò)這要取決于數(shù)據(jù)來(lái)更改的表格),這會(huì)顯著提高查詢數(shù)據(jù)的性能。

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

如果您有大量數(shù)據(jù)和許多不同的自定義帖子類型,WordPress可能會(huì)在wp_posts表上減慢查詢速度。 如果您發(fā)現(xiàn)查詢的帖子類型較慢,那么可以考慮從自定義帖子類型的存儲(chǔ)模型移動(dòng)到自定義表格中 - 更多內(nèi)容將在后面的文章中介紹。

結(jié)論

通過(guò)這些查詢優(yōu)化方法,我們?cè)O(shè)法將查詢從8秒降低到2秒,并且將查詢次數(shù)從4次減少到1次。需要說(shuō)明的是,這些查詢時(shí)間是在我們開(kāi)發(fā)環(huán)境運(yùn)行時(shí)記錄的 ,生產(chǎn)環(huán)境速度會(huì)更快。

這對(duì)追蹤查詢緩慢及其修復(fù)等問(wèn)題是一個(gè)有用的指南。 優(yōu)化查詢看起來(lái)可能像一個(gè)可怕的任務(wù),但只要你嘗試一下,并取得一些初步的勝利,你就會(huì)開(kāi)始找到錯(cuò)誤,并希望做出進(jìn)一步改善。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MSSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
2019国产精品| 欧美日韩性视频一区二区三区| 日韩在线观看你懂的| 97精品国产97久久久久久粉红| 国产色综合天天综合网| 欧美区国产区| 悠悠资源网亚洲青| а√资源新版在线天堂| 亚洲色图综合网| 中日韩av在线播放| 97操在线视频| 亚洲毛片av| 亚洲精品午夜国产va久久成人| 被下部羞羞漫画| 国产精品18p| 欧美日韩的一区二区| 伊人国产精品| 精品一区中文字幕| 成人黄色免费在线观看| 天堂√在线中文官网在线| 中文字幕 亚洲视频| 国内精品福利| 国产一区二区三区精品在线观看| 国模私拍一区二区国模曼安| 四虎影院影音| 国产精品成人免费电影| 一区二区日韩视频| 亚洲激情自拍视频| 一区二区欧美精品| 日本一二三不卡| 一色道久久88加勒比一| 国产午夜精品一区在线观看| 欧美剧在线免费观看网站| 欧美三级在线视频| 午夜伦欧美伦电影理论片| av在线观看地址| 天天干天天色天天爽| 超级砰砰砰97免费观看最新一期| 久久久久成人精品无码中文字幕| 波多野结衣一区二区在线| 欧美日韩国产丝袜美女| 亚洲美女网站18| 国产午夜精品全部视频播放| 无圣光视频在线观看| www.色五月| www.日韩免费| 亚洲国产精品成人无久久精品| 日韩免费中文字幕| 国精品无码一区二区三区| 成人影院一区二区三区| av先锋资源| 免费无码不卡视频在线观看| 中文字幕在线观看一区| 国产精品啊啊啊| 日日夜夜精品免费视频| 日本高清不卡码| 成人av在线资源网| 亚洲少妇屁股交4| 中文字幕第一页在线| www.欧美激情.com| 二区在线观看| 亚洲精品成人在线| 午夜久久久久久噜噜噜噜| 一区二区三区在线免费| 日韩美女视频免费看| 可以免费观看的毛片| 高清不卡av| 中日韩精品一区二区三区| 四虎电影院在线观看| 日本精品久久久久中文字幕| 免费毛片在线不卡| 自拍在线播放| 在线影视一区| 成人在线免费观看一区| 亚洲午夜成aⅴ人片| 国产精品99久久免费黑人人妻| 国产欧美一二三区| 超碰在线人人爱| 久久久久日韩精品久久久男男| 日本精品性网站在线观看| 国产成人在线中文字幕| 第一站视频久草网| 欧美日韩成人黄色| 含羞草激情视频| 污污的网站在线观看| 3dmax动漫人物在线看| 国产在线视频在线| 精品国产高清a毛片无毒不卡| 国产亚洲精品aa| 丁香激情综合五月| 国产女同互慰高潮91漫画| 五月天综合激情网| 亚洲国产精品suv| 91 com成人网| 日韩视频永久免费| 久久国产这里只有精品| 欧美理论一区二区| 在线观看国产欧美| 免费在线观看日韩| 精品无码国模私拍视频| 丝袜诱惑亚洲看片| se视频在线观看| 69av视频在线| 黄网站免费在线观看| 国产wwwxx| 国产欧美日韩视频一区二区三区| 精品国产福利一区二区在线| 97在线观看视频免费| 不卡一区二区三区四区五区| 国产精品美腿一区在线看| 成人在线高清免费| 一区二区三区四区五区在线| 欧美激情在线| 欧美日本一道本在线视频| 欧美视频第一页| 久久久久久亚洲精品不卡4k岛国| 另类少妇人与禽zozz0性伦| 91久久国产精品| 精品国产欧美一区二区三区成人| 欧美人与牲动交xxxx| 五月天六月丁香| 捆绑调教一区二区三区| 欧美人与动牲性行为| 亚洲av成人片无码| 8mav模特福利视频在线观看| 婷婷丁香激情网| 爱福利视频一区二区| 蜜桃av噜噜一区二区三| 亚洲国产日韩美| 99久热re在线精品996热视频| 9797在线看片亚洲精品| 久久久久久久久久久影院| 欧美日韩午夜电影网| 黑丝一区二区三区| 欧美黄网站在线观看| 久久精品女人天堂av免费观看| 高清久久久久久| 国产精品免费精品自在线观看| 国产成人精品网址| 国产在线拍偷自揄拍精品| 3d精品h动漫啪啪一区二区| 欧美在线视频在线播放完整版免费观看| 秋霞午夜在线观看| 牛牛电影国产一区二区| 中文xxx视频| 四虎久久免费| 国产精品久久久网站| 三级在线电影| 一本一道无码中文字幕精品热| 国产黄色片视频| 久久国产精品一区二区| 日韩精品在线免费| 欧美在线观看网站| 国产精品久久久久久久久久直播| 北岛玲heyzo一区二区| 两个人的视频www国产精品| 国产精品欧美一区二区三区| 毛片在线网站| 精品日产卡一卡二卡麻豆| 2021国产精品久久精品| 久久久久久久国产精品毛片| 视频精品国内| 成人免费毛片app| 午夜精品久久久久久久99热影院| 91蜜桃网址入口| 小说区图片区综合久久88| 亚洲免费在线播放视频| 国产精品国产三级国产普通话蜜臀| 国产成人精品久久| 色婷婷激情久久| 久久精品免费av| 亚洲精品无码专区在线播放| 亚洲国产成人久久综合| 激情综合视频| eeuss影影院www在线播放| 欧美成人观看免费全部完小说| 国产精品伦一区二区三区| 色悠悠久久综合网| 欧美日韩国产网站| 丁香啪啪综合成人亚洲| 欧美三级视频在线| 94色蜜桃网一区二区三区| 免费看黄色片的网站| 欧美一区二区三区在线观看| 欧美在线视频网| 成人丝袜视频网| 日本xxxxxwwwww| 亚洲精品中文字幕乱码三区不卡| 久久久久久美女精品| 欧美91精品| 亚洲 小说区 图片区| 麻豆视频在线观看| 国产97在线|日韩| 午夜久久久久久久久久影院| 久久在线免费视频| 国产高清在线免费| 国产精品伦理一区二区三区| 草草视频在线播放| 日本福利片免费看| 亚洲图片在线观看| 黄色片网站免费在线观看| 欧美一卡二卡在线| 夜鲁很鲁在线视频| 日本久久久久久久| 中文av资源在线| 色综合天天性综合| 国产精品nxnn| 亚洲成人第一| 天堂v在线观看| www.色五月.com| 国产成人无码一区二区在线观看| 精品电影一区二区| 久久er99热精品一区二区三区| 天堂а√在线中文在线鲁大师| 一本色道久久综合亚洲精品婷婷| 影音先锋国产在线| 午夜精品久久久久久久蜜桃| 菠萝蜜视频网址| 欧美亚洲另类小说| 婷婷精品进入| 亚洲视频在线免费观看| 国产 中文 字幕 日韩 在线| 国产午夜久久久| 最新亚洲激情| 美乳少妇欧美精品| 日韩综合精品| 最近高清中文在线字幕在线观看1| 黄页免费欧美| 成人激情直播| 久久亚洲免费视频| 中文字幕av不卡| 日本精品网站| 国产精品极品在线| 51午夜精品| 欧美一区二区三区久久久| 一本之道久久| 销魂美女一区二区三区视频在线| 影音先锋亚洲电影| 亚洲一二三区不卡| 91精品国产99久久久久久| 亚洲无吗一区二区三区| 菠萝菠萝蜜在线视频免费观看| 91亚洲精品乱码久久久久久蜜桃| 日本在线啊啊| 97久久国产亚洲精品超碰热| 亚洲性猛交富婆| 日本美女一区二区三区视频| 亚洲电影二区| 美女福利网站视频在线观看| 中文字幕欧美日韩在线| 国产偷国产偷亚洲清高网站| 中日韩美女免费视频网站在线观看| 黄色av片三级三级三级免费看| 久久人人爽人人爽人人| 中文字幕亚洲电影| 黄色激情小视频| 欧洲一区二区在线| 日本a级片视频| 日韩中文字幕在线不卡| 日韩在线免费视频观看| 亚洲www在线| 2020天天干夜夜爽| 国产精品**亚洲精品| 欧美黑人3p| 你懂的视频网| 9999精品视频| 影音先锋制服丝袜| 黄色一级在线视频| 青青艹在线视频| 国产成人毛片| 国产精品露出视频| 午夜伦理大片视频在线观看| 亚洲激情视频网| 日韩av在线一区二区三区| 婷婷丁香综合网| 91福利精品视频| 日韩视频在线观看视频| 精品免费av| 黄色在线小视频| 在线国产1区| 四虎成人影院网址| 中文字幕色呦呦| 久久久久成人精品免费播放动漫| 一本色道久久综合亚洲二区三区| 国产精品视频第一区二区三区| 国产尤物精品| 私密视频在线观看| 宅男av一区二区三区| 欧美大片在线看免费观看| 国产欧美一区二区三区在线老狼| 91成品视频入口| 91精品国产沙发| 高清国语自产拍免费一区二区三区| 99热超碰在线| 欧美激情一区二区| 成人免费观看视频| 成人三级毛片| 麻豆国产精品一区二区三区| 日本高清视频在线播放| 蜜臀视频一区二区三区| 超碰在线公开97| 国产精品久久久久99| 亚洲 国产 欧美 日韩| 好妞色妞国产在线视频| 久久久噜久噜久久综合| 午夜高潮免费视频| 亚洲精品久久久久久久久久久久| 精品美女在线播放| 美女脱光内衣内裤视频久久网站| 亚洲最新无码中文字幕久久| 国产999免费视频| 国产精品色婷婷久久58| 三级在线免费观看| xfplay资源站夜色先锋5566| 四虎国产成人精品免费一女五男| 中文字幕一区二区人妻电影| 久久精品九色| 欧美电影免费网站| 中文字幕日本欧美| 国产精品超碰| 在线免费中文字幕| 国产成人免费av一区二区午夜| 欧美性猛交xxxx乱大交| 日韩中文字幕91| 欧美日韩国产一区二区| 日韩欧美主播在线| 97精品中文字幕| 99精品视频在线观看播放|