Postgresql字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别
2018-03-03 14:32
302 查看
最近在做了一个关于postgreSQL相关的项目,个人工作中遇到了关于字符串检索的一些处理,以下是个人对字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~*的理解,不正之处还请指出
![](https://oscdn.geek-share.com/Uploads/Images/Content/201707/61c17ed2eb67211a84e137429ac3f7ad.gif)
LIKESelect * from test where varchar like ‘_a%’; varchar匹配任何a前有一个字符的字符串。‘_’与’%’为通配符。’_’匹配任意一个字符,’%’匹配0至多个任意字符。ESCAPESelect* from test where varchar like ‘b_a%’escape ‘b’; varchar 匹配任何以’_a’开头的字符串。ESCAPE 'escape_character' 允许在字符串中搜索通配符而不是将其作为通配符使用。请注意反斜杠在字符串文本里已经有特殊含义了,所以如果你写一个包含反斜杠的模式常量,那你就要在 SQL 语句里写两个反斜杠。因此,写一个匹配单个反斜杠的模式实际上要在语句里写四个反斜杠。你可以通过用 ESCAPE 选择一个不同的逃逸字符来避免这样;这样反斜杠就不再是 LIKE 的特殊字符了。但仍然是字符文本分析器的特殊字符,所以你还是需要两个反斜杠。
我们也可以通过写成 ESCAPE '' 的方式关闭逃逸机制,这时,我们就不能关闭下划线和百分号的特殊含义。
ILIKESelect * 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)
LIKESelect * from test where varchar like ‘_a%’; varchar匹配任何a前有一个字符的字符串。‘_’与’%’为通配符。’_’匹配任意一个字符,’%’匹配0至多个任意字符。ESCAPESelect* from test where varchar like ‘b_a%’escape ‘b’; varchar 匹配任何以’_a’开头的字符串。ESCAPE 'escape_character' 允许在字符串中搜索通配符而不是将其作为通配符使用。请注意反斜杠在字符串文本里已经有特殊含义了,所以如果你写一个包含反斜杠的模式常量,那你就要在 SQL 语句里写两个反斜杠。因此,写一个匹配单个反斜杠的模式实际上要在语句里写四个反斜杠。你可以通过用 ESCAPE 选择一个不同的逃逸字符来避免这样;这样反斜杠就不再是 LIKE 的特殊字符了。但仍然是字符文本分析器的特殊字符,所以你还是需要两个反斜杠。
我们也可以通过写成 ESCAPE '' 的方式关闭逃逸机制,这时,我们就不能关闭下划线和百分号的特殊含义。
例子: 查找数据库中表的名字(查找以tbl_开头的表的名字) select tablename from pg_tables where tablename like 'tbl!_%'ESCAPE '!'; 利用escape转义: 上面的sql语句中就是将!作为转义字符,作用是将"_"转换成普通的"_"
ILIKESelect * 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, ~, ~*, !~, !~* 的含义和区别
- SQL字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和区别
- 字符串格式化符号含义及转义字符含义
- postgresql~*符号的含义
- PostgreSQL 多重含义数组检索与条件过滤 (标签1:属性, 标签n:属性) - 包括UPSERT操作如何修改数组、追加数组元素
- linux中shell截取字符串方法总结 关键符号${}
- JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解
- infobright 字符串操作like 和 = 的区别
- PostgreSQL模式匹配关键字similar to 和 like 的区别
- 字符串格式化符号含义及转义字符含义
- JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解
- JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解
- python字符串符号区别
- JS 字符串编码函数(解决URL特殊字符传递问题):escape()、encodeURI()、encodeURIComponent()区别详解
- 对于在ruby中,字符串和符号区别的补充
- 字符串的方法及注释/ 字符串格式化符号含义及转义字符含义(python)
- 三个可以对字符串编码的函数escape()、encodeURI()、encodeURIComponent()之间的区别详解
- ibatis #和$符号的区别,传入字符串而不加引号
- 字符串格式化符号含义及转义字符含义
- C++中的const关键定代表什么含义?跟C语言中的const有什么区别