[SQL] 萬用字元與escape的用法(必知)

萬用字元用法

  • %:匹配零個及多個任意字元
  • _ :與任意1個單字元匹配,包含
  • []:匹配一個範圍
  • [^]:排除一個範圍

字串中出現的特殊字元:% [ [] _

可以使用 ‘[]’ 把特殊字元包起來,這些特殊字元就被當作普通字元對待了。

[、]、[]及[1]的四種範例:

以下SQL使用 like [] 匹配特殊字元 [ 與 []

-- 使用[[]
select 1 where '[TEST' like '[[]%'; -- 1
select 1 where 'TEST[' like '%[[]'; -- 1

-- 這邊的]是不需要包起來,只需要寫在like內即可
select 1 where 'TEST]' like '%]'; -- 1
select 1 where ']TEST' like ']%'; -- 1

-- 使用[[]]
select 1 where '[]TEST' like '[[]]%%'; -- 1

-- 稍微複雜一點包法,前面的[1]要用[[]1]包
select 1 where '[1]TEST' like '[[]1]%%'; -- 1

使用 like [] 匹配特殊字元

原本 _ 的功能是與任意單字元匹配,
如果想搜尋是DB_開頭的話,使用單純的_又會把DBa、DBb什麼db開頭的家人都找出來,變模糊搜尋了。

--原本:
select 1 where 'DB_' like '___'; -- 1
select 1 where 'DBa' like '___'; -- 1
select 1 where 'DBb' like '___'; -- 1

如果確定只要DB_開頭,就必須把_用[]包起來,這樣其他的就找不到了!

select 1 where 'DBatest' like 'db[_]%'; -- 無
select 1 where 'DBbtest' like 'db[_]%'; -- 無
select 1 where 'DB_test' like 'db[_]%'; -- 1

escape的用法

escape要與Like一起使用,定義轉義符
若不使用[]包住%,來搜尋’10%’,也許會很直覺的使用like '10%'
但這樣會把100%、101%、1000%等10開頭都搜尋到,與預期結果不符。

SELECT 1 WHERE '100%' LIKE '10%'; -- 1
SELECT 1 WHERE '101%' LIKE '10%'; -- 1
SELECT 1 WHERE '102%' LIKE '10%'; -- 1
SELECT 1 WHERE '10000%' LIKE '10%'; -- 1

下方指令是使用escape來尋找真正的%

 SELECT 1 WHERE '10%' LIKE '10/%'  ESCAPE '/'  ;

上方的是指定用’/’符號來說明,後面的萬用符轉成普通字符(單純的百分比%),
如果同時要尋找/的話呢?例如日期常使用到的/
一般沒有使用ESCAPE的話,可能直接打上日期(下方第一個)搜尋,
若加入 ESCAPE ‘/’ ,要使用2個/,這樣才能符合。

SELECT 1 WHERE '2021/12/31' LIKE '2021/12/31'; -- 1
SELECT 1 WHERE '2021/12/31' LIKE '2021//12//31'  ESCAPE '/'; -- 1
SELECT 1 WHERE 'MSSQL/50%' LIKE 'MSSQL/50%'  ESCAPE '/'; -- 0
SELECT 1 WHERE 'MSSQL/50%' LIKE 'MSSQL//50/%'  ESCAPE '/'; -- 1

發佈留言

內容索引