• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    postgresql~*符号的含义及用法说明

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

    另外:

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

    ~*搜索 匹配正则表达式,大小写无关 'thomas' ~* '.*Thomas.*'

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

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

    补充:Postgresql字符串检索关键是和符号 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' 允许在字符串中搜索通配符而不是将其作为通配符使用。

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

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

    你可以通过用 ESCAPE 选择一个不同的逃逸字符来避免这样;这样反斜杠就不再是 LIKE 的特殊字符了。

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

    我们也可以通过写成 ESCAPE '' 的方式关闭逃逸机制,这时,我们就不能关闭下划线和百分号的特殊含义。

    例子:

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

    select tablename from pg_tables where tablename like 'tbl!_%'ESCAPE '!';

    利用escape转义: 上面的sql语句中就是将!作为转义字符,作用是将"_"转换成普通的"_"

    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'的字符串。

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

    您可能感兴趣的文章:
    • 浅谈PostgreSQL中大小写不敏感问题
    • PostgreSQL LIKE 大小写实例
    • Postgresql 数据库转义字符操作
    • postgresql数据库使用说明_实现时间范围查询
    • postgresql 实现将数组变为行
    • 基于PostgreSql 别名区分大小写的问题
    上一篇:postgres array_to_string和array的用法讲解
    下一篇:Postgresql 数据库转义字符操作
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    postgresql~*符号的含义及用法说明 postgresql,符,号的,含义,及,