根據(jù)某一條件從數(shù)據(jù)庫表中查詢 『有』與『沒有』渔扎,只有兩種狀態(tài)硫狞,那為什么在寫SQL的時(shí)候,還要SELECT count(*) 呢赞警?無論是剛?cè)氲赖某绦騿T新星妓忍,還是精湛沙場多年的程序員老白,都是一如既往的count
目前多數(shù)人的寫法
多次REVIEW代碼時(shí)愧旦,發(fā)現(xiàn)如現(xiàn)現(xiàn)象:業(yè)務(wù)代碼中,需要根據(jù)一個(gè)或多個(gè)條件定罢,查詢是否存在記錄笤虫,不關(guān)心有多少條記錄。普遍的SQL及代碼寫法如下
#### SQL寫法:
SELECT count(*) FROM table WHERE a = 1 AND b = 2
#### Java寫法:
int nums = xxDao.countXxxxByXxx(params);
if ( nums > 0 ) {
//當(dāng)存在時(shí)祖凫,執(zhí)行這里的代碼
} else {
//當(dāng)不存在時(shí)琼蚯,執(zhí)行這里的代碼
}
是不是感覺很OK,沒有什么問題
優(yōu)化方案
推薦寫法如下:
#### SQL寫法:
SELECT 1 FROM table WHERE a = 1 AND b = 2 LIMIT 1
#### Java寫法:
Integer exist = xxDao.existXxxxByXxx(params);
if ( exist != NULL ) {
//當(dāng)存在時(shí)惠况,執(zhí)行這里的代碼
} else {
//當(dāng)不存在時(shí)遭庶,執(zhí)行這里的代碼
}
SQL不再使用count,而是改用LIMIT 1稠屠,讓數(shù)據(jù)庫查詢時(shí)遇到一條就返回峦睡,不要再繼續(xù)查找還有多少條了業(yè)務(wù)代碼中直接判斷是否非空即可
總結(jié)
根據(jù)查詢條件查出來的條數(shù)越多翎苫,性能提升的越明顯,在某些情況下榨了,還可以
END
本文發(fā)于 微星公眾號「程序員的成長之路」煎谍,回復(fù)「1024」你懂得,給個(gè)贊唄龙屉。
回復(fù) [ 256 ] Java 程序員成長規(guī)劃
回復(fù) [ 777 ] 接私活的七大平臺利器
回復(fù) [ 2048 ] 免費(fèi)領(lǐng)取C/C++呐粘,Linux,Python转捕,Java作岖,PHP,人工智能五芝,單片機(jī)痘儡,樹莓派,等 5T 學(xué)習(xí)資