SQL字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别

最近在做了一个关于postgreSQL相关的项目,个人工作中遇到了关于字符串检索的一些处理,以下是个人对字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~*的理解,不正之处还请指出


LIKE

Select * from test where varchar like ‘_a%’; varchar匹配任何a前有一个字符的字符串。

‘_’与’%’为通配符。’_’匹配任意一个字符,’%’匹配0至多个任意字符。

ESCAPE

Select* from test where varchar like ‘b_a%’escape ‘b’; varchar 匹配任何以’_a’开头的字符串。

ESCAPE 'escape_character' 允许在字符串中搜索通配符而不是将其作为通配符使用。

ILIKE

Select * from test where varchar  ilike ‘_a%’; varchar匹配任何a或者A前有一个字符的字符串。

与Like相比,ILike忽略大小写。

 

正则表达式匹配操作符

~  匹配正则表达式,大小写相关

Select * from test where varchar  ~ ‘ab‘; varchar匹配任何包含’ab’的字符串。

 

~* 匹配正则表达式,大小写无关

Select * from test where varchar ~‘AB‘;varchar匹配任何包含’ab’、’aB’、’Ab’、’AB’的字符串。

与’ ~’相比,忽略大小写。

 

!~  不匹配正则表达式,大小写相关

Select * from test where varchar  ~ ‘a‘; varchar匹配任何不包含’a’的字符串。

 

!~* 不匹配正则表达式,大小写无关

select * from test where varchar !~* ‘A‘; varchar匹配任何不包含’a’和’A’的字符串。

你可能感兴趣的:(SQL字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别)