自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

巧用SQL中case when語句實(shí)現(xiàn)模糊查詢

數(shù)據(jù)庫 SQL Server
如果我們?cè)陂_發(fā)項(xiàng)目的過程中,需要進(jìn)行模糊查詢,應(yīng)該怎么做呢?下面就將為您介紹使用SQL中case when語句實(shí)現(xiàn)模糊查詢的方法,供您參考。

使用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ù):

  1. 1 DECLARE @FirstName  NVARCHAR(10),  
  2. 2         @LastName   NVARCHAR(20);  
  3. 3 SELECT @FirstName = '',   
  4. 4        @LastName = '';   
  5. 5 SELECT *   
  6. 6 FROM   Employees c  
  7. 7 WHERE  CHARINDEX(  
  8. 8            (  
  9. 9                CASE   
  10. 10                     WHEN @FirstName = '' THEN FirstName  
  11. 11                     ELSE @FirstName  
  12. 12                END  
  13. 13            ),  
  14. 14            FirstName  
  15. 15        ) > 0  
  16. 16        AND CHARINDEX(  
  17. 17                (CASE WHEN @LastName = '' THEN LastName ELSE @LastName END),  
  18. 18                LastName  
  19. 19            ) > 0 

 

 

 

【編輯推薦】

SQL中if語句的用法示例

巧用SQL server臨時(shí)表

速學(xué)如何定義SQL存儲(chǔ)過程

判斷sql server表是否存在的方法

SQL Server表變量和臨時(shí)表的區(qū)別

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2024-10-15 16:53:07

2010-09-07 14:56:49

SQL語句CASE WHEN

2010-10-08 15:54:34

mysql中case

2011-03-07 13:27:13

SQLCase

2010-11-18 13:40:48

mysql分頁查詢

2010-09-26 10:35:47

sql替換語句

2010-09-07 09:45:48

SQL語句

2011-07-29 14:39:11

CASE WHEN E

2010-09-25 16:17:25

SQL語句

2010-10-21 10:28:13

SQL Server查

2018-12-25 14:40:04

SQL ServerSQL語句數(shù)據(jù)庫

2010-09-07 14:45:34

sql語句

2023-05-26 07:08:05

CSS模糊實(shí)現(xiàn)文字

2018-12-26 09:25:30

SQL ServerSQL語句數(shù)據(jù)庫

2010-09-07 10:35:38

SQL語句

2009-06-08 21:45:46

Javaswitch-case

2010-09-26 17:09:05

SQL語句

2021-08-30 06:20:39

CSS 技巧3D 效果

2009-07-24 16:59:57

iBatis模糊查詢

2010-10-29 16:41:12

Oracle模糊查詢
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)