- 相關(guān)推薦
php+mysql查詢(xún)優(yōu)化簡(jiǎn)單實(shí)例
PHP+Mysql是一個(gè)最經(jīng)常使用的黃金搭檔,它們倆配合使用,能夠發(fā)揮出最佳性能,當(dāng)然,如果配合Apache使用,就更加Perfect了。下面是小編整理的php+mysql查詢(xún)優(yōu)化的方法。分享給大家供大家參考。更多相關(guān)信息請(qǐng)關(guān)注相關(guān)欄目!
做好對(duì)mysql的查詢(xún)優(yōu)化,下面通過(guò)一個(gè)簡(jiǎn)單的例子,展現(xiàn)不同的SQL語(yǔ)句對(duì)于查詢(xún)速度的影響.
存在這樣的一張表test,它有一個(gè)自增的id作為主索引,現(xiàn)在要查詢(xún)id號(hào)處于某一個(gè)范圍內(nèi)的記錄,可以使用如下SQL語(yǔ)句:
復(fù)制代碼 代碼如下:SELECT *
FROM `test`
order by id asc
limit 208888,50
這條SQL語(yǔ)句的意思是從id號(hào)為208888的記錄開(kāi)始向后取50條記錄,在一個(gè)30萬(wàn)條記錄的數(shù)據(jù)庫(kù)中測(cè)試,在主索引都已經(jīng)建立好的情況下,執(zhí)行這條語(yǔ)句的時(shí)間為40~50秒,那么有沒(méi)有更快SQL語(yǔ)句來(lái)執(zhí)行呢?顯然是有的,看看下面這條SQL語(yǔ)句:
復(fù)制代碼 代碼如下:SELECT *
FROM `test`
WHERE id
BETWEEN 208838
AND 208888
這條語(yǔ)句使用了一個(gè)條件進(jìn)行過(guò)濾,在實(shí)際中測(cè)試的執(zhí)行時(shí)間約為0.06秒.
究其原因,是因?yàn)殡m然id屬性上已經(jīng)有索引了,但是排序仍然是一個(gè)非常高代價(jià)的操作,要慎用,而第二個(gè)語(yǔ)句,就可以讓MySql充分利用數(shù)據(jù)庫(kù)中已經(jīng)建立好的B+樹(shù)索引,所以查找起來(lái)速度相當(dāng)快,是原來(lái)的幾百倍.
由此可見(jiàn),網(wǎng)站開(kāi)發(fā)者在使用SQL語(yǔ)句的時(shí)候,一定要小心謹(jǐn)慎,因?yàn)橐粋(gè)疏忽大意的SQL語(yǔ)句,可能使得你的網(wǎng)站訪(fǎng)問(wèn)速度急劇下降,后臺(tái)數(shù)據(jù)庫(kù)面臨巨大壓力,并且很快陷入無(wú)法打開(kāi)頁(yè)面的窘境.
【php+mysql查詢(xún)優(yōu)化簡(jiǎn)單實(shí)例】相關(guān)文章:
php+mysql實(shí)現(xiàn)無(wú)限分類(lèi)實(shí)例詳解07-23
php+mysql結(jié)合Ajax實(shí)現(xiàn)點(diǎn)贊功能完整實(shí)例07-20
php查詢(xún)mysql多條件判斷輸出展示實(shí)例04-20
PHP語(yǔ)言:MySQL五個(gè)查詢(xún)優(yōu)化方法02-21