這篇文章主要介紹了php+mysql查詢(xún)優(yōu)化簡(jiǎn)單實(shí)例,分析了php+mysql程序設(shè)計(jì)中關(guān)于SQL語(yǔ)句優(yōu)化查詢(xún)的技巧,對(duì)于提高查詢(xún)效率有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例分析了php+mysql查詢(xún)優(yōu)化的方法。分享給大家供大家參考。具體分析如下:
PHP+Mysql是一個(gè)最經(jīng)常使用的黃金搭檔,它們倆配合使用,能夠發(fā)揮出最佳性能,當(dāng)然,如果配合Apache使用,就更加Perfect了.
因此,需要做好對(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ǔ)句:
代碼如下:
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ǔ)句:
代碼如下:
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)站訪問(wèn)速度急劇下降,后臺(tái)數(shù)據(jù)庫(kù)面臨巨大壓力,并且很快陷入無(wú)法打開(kāi)頁(yè)面的窘境.
希望本文所述對(duì)大家的php+mysql程序設(shè)計(jì)有所幫助。
更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄