相思资源网 Design By www.200059.com

操作符 ~~ 等效于 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,~*符号

相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com

评论“postgresql~*符号的含义及用法说明”

暂无postgresql~*符号的含义及用法说明的评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。