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