這篇文章主要介紹了php+mysql查詢優(yōu)化簡單實(shí)例,分析了php+mysql程序設(shè)計(jì)中關(guān)于SQL語句優(yōu)化查詢的技巧,對于提高查詢效率有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例分析了php+mysql查詢優(yōu)化的方法。分享給大家供大家參考。具體分析如下:
PHP+Mysql是一個(gè)最經(jīng)常使用的黃金搭檔,它們倆配合使用,能夠發(fā)揮出最佳性能,當(dāng)然,如果配合Apache使用,就更加Perfect了.
因此,需要做好對mysql的查詢優(yōu)化,下面通過一個(gè)簡單的例子,展現(xiàn)不同的SQL語句對于查詢速度的影響.
存在這樣的一張表test,它有一個(gè)自增的id作為主索引,現(xiàn)在要查詢id號處于某一個(gè)范圍內(nèi)的記錄,可以使用如下SQL語句:
代碼如下:
SELECT *
FROM `test`
order by id asc
limit 208888,50
這條SQL語句的意思是從id號為208888的記錄開始向后取50條記錄,在一個(gè)30萬條記錄的數(shù)據(jù)庫中測試,在主索引都已經(jīng)建立好的情況下,執(zhí)行這條語句的時(shí)間為40~50秒,那么有沒有更快SQL語句來執(zhí)行呢?顯然是有的,看看下面這條SQL語句:
代碼如下:
SELECT *
FROM `test`
WHERE id
BETWEEN 208838
AND 208888
這條語句使用了一個(gè)條件進(jìn)行過濾,在實(shí)際中測試的執(zhí)行時(shí)間約為0.06秒.
究其原因,是因?yàn)殡m然id屬性上已經(jīng)有索引了,但是排序仍然是一個(gè)非常高代價(jià)的操作,要慎用,而第二個(gè)語句,就可以讓MySql充分利用數(shù)據(jù)庫中已經(jīng)建立好的B+樹索引,所以查找起來速度相當(dāng)快,是原來的幾百倍.
由此可見,網(wǎng)站開發(fā)者在使用SQL語句的時(shí)候,一定要小心謹(jǐn)慎,因?yàn)橐粋€(gè)疏忽大意的SQL語句,可能使得你的網(wǎng)站訪問速度急劇下降,后臺數(shù)據(jù)庫面臨巨大壓力,并且很快陷入無法打開頁面的窘境.
希望本文所述對大家的php+mysql程序設(shè)計(jì)有所幫助。
更多信息請查看IT技術(shù)專欄