巧用SQL中case when語(yǔ)句實(shí)現(xiàn)模糊查詢
當(dāng)前位置:點(diǎn)晴教程→知識(shí)管理交流
→『 技術(shù)文檔交流 』
使用SQL中case when語(yǔ)句,可以實(shí)現(xiàn)我們需要的模糊查詢,下面為您介紹SQL case when語(yǔ)句實(shí)現(xiàn)模糊查詢的腳本,希望對(duì)您學(xué)習(xí)SQL中case when語(yǔ)句的使用有所啟示。 我們?cè)谶M(jìn)行項(xiàng)目開(kāi)發(fā)中,經(jīng)常會(huì)遇到多條件模糊查詢的需求。對(duì)此,我們常見(jiàn)的解決方案有兩種:一是在程序端拼接SQL字符串,根據(jù)是否選擇了某個(gè)條件,構(gòu)造相應(yīng)的SQL字符串;二是在數(shù)據(jù)庫(kù)的存儲(chǔ)過(guò)程中使用動(dòng)態(tài)的SQL語(yǔ)句。其本質(zhì)也是拼接SQL字符串,不過(guò)是從程序端轉(zhuǎn)移到數(shù)據(jù)庫(kù)端而已。 這兩種方式的缺點(diǎn)是顯而易見(jiàn)的:一是當(dāng)多個(gè)條件每個(gè)都可為空時(shí),要使用多個(gè)if語(yǔ)句進(jìn)行判斷;二是拼接的SQL語(yǔ)句容易產(chǎn)生SQL注入漏洞。 最近寫數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的時(shí)候經(jīng)常使用case when 語(yǔ)句,正好可以用這個(gè)語(yǔ)句解決一下以上問(wèn)題。以SQL中的NorthWind數(shù)據(jù)庫(kù)為例,我要操作的是其中的Employees表,該表中默認(rèn)數(shù)據(jù)如下: 使用如下腳本來(lái)查詢表中數(shù)據(jù):
該文章在 2011/5/4 18:36:02 編輯過(guò) |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |