萬用字元用法
- %:匹配零個及多個任意字元
- _ :與任意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