SQL字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别
2011-11-20 14:06
573 查看
最近在做了一个关于postgreSQL相关的项目,个人工作中遇到了关于字符串检索的一些处理,以下是个人对字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~*的理解,不正之处还请指出
![](https://oscdn.geek-share.com/Uploads/Images/Content/201707/61c17ed2eb67211a84e137429ac3f7ad.gif)
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’的字符串。
![](https://oscdn.geek-share.com/Uploads/Images/Content/201707/61c17ed2eb67211a84e137429ac3f7ad.gif)
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, ~, ~*, !~, !~* 的含义和区别
- Postgresql字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别
- 截取字符串--sql和access的区别
- 字符串格式化符号含义及转义字符含义
- asp 格式化sql中的like字符串
- 多字段模糊查询sql like %% 优化与区别
- SQL 创建函数的样例(按指定的符号分割字符串,并返回临时表)
- 05字符串格式化符号含义以及转义符号含义
- python-字符串格式化符号含义
- 字符串格式化符号含义及转义字符含义
- 多字段模糊查询sql like %% 优化与区别
- asp 格式化sql中的like字符串
- 字符串格式化符号含义及转义字符含义
- sql中全文检索CHARINDEX 和PATINDEX 区别
- PB 中用带参数的 SQL 语句字符串检索数据并动态生成Datawindow
- 检索06 - Oracle MySql SqlSever之间的区别和优缺点
- JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解
- 字符串格式化符号含义及转义字符含义
- t-sql - like转义特殊符号
- MySQL之SQL MySQL正则表达式 LIKE与REGEXP的区别