网通服务器-postgresql~*符号的含义及用法说明

这篇网通服务器文章首要介绍了postgresql~*符号的含义及用法说明,具有非常好的参考价值,希望对我们起到必定的帮忙。一起跟从小编过来看看吧。

操作符 ~~ 等效于 LIKE, 而 ~~* 对应 ILIKE。 还有 !~~ 和 !~~* 操作符 分别代表 NOT LIKE 和 NOT ILIKE。

其他:

~ 匹配正则表达式,大小写相关 ‘thomas’ ~ ‘.*thomas.*’

~*查找 匹配正则表达式,大小写无关 ‘thomas’ ~* ‘.*Thomas.*’

!~ 不匹配正则表达式,大小写相关 ‘thomas’ !~ ‘.*Thomas.*’

!~* 不匹配正则表达式,大小写无关 ‘thomas’ !~* ‘.*vadim.*’

补偿:Postgresql字符串检索关键是和符号 LIKE, ESCAPE, ILIKE, ~, ~*, !~, !~* 的含义和差异

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

LIKE1Select * from test where varchar like ‘_a%’;

varchar匹配任何a前有一个字符的字符串。

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

ESCAPE1Select* from test where varchar like ‘b_a%’escape ‘b’;

varchar 匹配任何以’_a’开始的字符串。

ESCAPE ‘escape_character’ 答应在字符串中查找通配符而不是将其作为通配符运用。

请注意反斜杠在字符串文本里已经有特别含义了,所以假设你写一个包含反斜杠的方式常量,那你就要在 SQL 语句里写两个反斜杠。

因此,写一个匹配单个反斜杠的方式实际上要在语句里写四个反斜杠。

你能够毕竟靠用 ESCAPE 选择一个不同的逃逸字符来避免这样;这样反斜杠就不再是 LIKE 的特别字符了。

但仍然是字符文本分析器的特别字符,所以你仍是需求两个反斜杠。

我们也能够毕竟靠写成 ESCAPE ” 的办法关闭逃逸机制,这时,我们就不能关闭下划线和百分号的特别含义。

比方:

查找数据库中表的名字(查找以tbl_开始的表的名字)

1select tablename from pg_tables where tablename like ‘tbl!_%’ESCAPE ‘!’;

运用escape转义: 上面的sql语句中就是将!作为转义字符,作用是将”_”转换成一般的”_”

ILIKE1Select * from test where varchar ilike ‘_a%’;

varchar匹配任何a或许A前有一个字符的字符串。

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

正则表达式匹配操作符

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

1Select * from test where varchar ~ ‘ab‘;

varchar匹配任何包含’ab’的字符串。

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

1Select * from test where varchar ~‘AB‘;

varchar匹配任何包含’ab’、’aB’、’Ab’、’AB’的字符串。

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

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

1Select * from test where varchar ~ ‘a‘;

varchar匹配任何不包含’a’的字符串。

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

1select * from test where varchar !~* ‘A‘;

varchar匹配任何不包含’a’和’A’的字符串。