PostgreSQL正则表达式查询

参考http://www.php100.com/manual/PostgreSQL8/functions-matching.html

LIKE

string LIKE pattern [ ESCAPE escape-character ]
string NOT LIKE pattern [ ESCAPE escape-character ]

每个 pattern 定义一个字串的集合。 如果该 string 包含在 pattern 代表的字串集合里,那么 LIKE 表达式返回真。 (和我们想象的一样,如果 LIKE 返回真,那么 NOT LIKE 表达式返回假, 反之亦然。一个等效的表达式是 NOT (string LIKE pattern).)

如果 pattern 不包含百分号 或者下划线,那么该模式只代表它本身; 这时候 LIKE 的行为就象等号操作符。 在 pattern 里的下划线 (_)代表(匹配)任何单个字符; 而一个百分号(%)匹配任何零或更多 字符长的字串。

下面是一些例子∶

‘abc‘ LIKE ‘abc‘    true
‘abc‘ LIKE ‘a%‘     true
‘abc‘ LIKE ‘_b_‘    true
‘abc‘ LIKE ‘c‘      false
LIKE 模式匹配总是覆盖整个字串。 要匹配在字串内部任何位置的序列,该模式必须以百分号开头和结尾。LIKE运算符也可以匹配指定的字符串,但与~不同,LIKE匹配的字符串如果在文本中间出现,则找不到它,相应的行也不会返回。而~在文本进行匹配,如果被匹配的字符串在文本中出现,~将会找到它,相应的行会被返回。
Table 正则表达式匹配操作符(注意:~相当于like)
操作符 描述 例子
~ 匹配正则表达式,大小写相关 ‘thomas‘ ~ ‘.*thomas.*‘
~* 匹配正则表达式,大小写无关 ‘thomas‘ ~* ‘.*Thomas.*‘
!~ 不匹配正则表达式,大小写相关 ‘thomas‘ !~ ‘.*Thomas.*‘
!~* 不匹配正则表达式,大小写无关 ‘thomas‘ !~* ‘.*vadim.*‘

正则表达式量词

量词 匹配
* 一个匹配 0 或者更多个原子的序列
+ 一个匹配 1 或者更多个原子的序列
? 一个匹配 0 个或者 1 个原子的序列
{m} 一个正好匹配 m 个原子的序列
{m,} 一个匹配m 个或者更多原子的序列
{m,n} 一个匹配 m 到 n 个(包含两端) 原子的序列;m 不能比 n 大
*? * 的非贪婪模式
+? + 的非贪婪模式
?? ? 的非贪婪模式
{m}? {m} 的非贪婪模式
{m,}? {m,} 的非贪婪模式
{m,n}? {m,n} 的非贪婪模式

{...} 的形式被称作范围。 一个范围内的数字 m 和 n 都是无符号十进制整数, 允许的数值从 0 到 255(闭区间)。

 正则表达式约束

约束 描述
^ 匹配字串的开头
$ 匹配字串的结尾
(?=re) 正前瞻 匹配任何匹配 re 的 子字串起始点(只在 ARE 中有)
(?!re) 负前瞻 匹配任何不匹配 re 的子字串的起始点。(只在 ARE 中有)
时间: 2024-08-01 16:12:32

PostgreSQL正则表达式查询的相关文章

Postgresql 正则表达式【转】

原文:http://blog.csdn.net/wugewuge/article/details/7704996 postgresql支持POSIX 风格的正则表达式,在postgresql中使用正则表达式时需要使用关键字“~”,以表示该关键字之前的内容需匹配之后的正则表达式,若匹配规则不需要区分大小写,可以使用组合关键字“~*”: 相反,若需要查询不匹配这则表达式的记录,只需在该关键字前加否定关键字“!”即可.若正则表达式包含转义字符,则需在表达式前加关键字“E”. 例如: select *

[Elasticsearch] 部分匹配 (二) - 通配符及正则表达式查询

通配符和正则表达式查询 wildcard查询和prefix查询类似,也是一个基于词条的低级别查询.但是它能够让你指定一个模式(Pattern),而不是一个前缀(Prefix).它使用标准的shell通配符:?用来匹配任意字符,*用来匹配零个或者多个字符. 以下查询能够匹配包含W1F 7HW和W2F 8HW的文档: GET /my_index/address/_search { "query": { "wildcard": { "postcode"

mysql中使用正则表达式查询

正则表达式功能确实很强大,那天专门抽空学学,这里就暂时在mysql查询中用用. 正则表达式强大而灵活,可以应用于非常复杂的查询. 选项 说明(自动加匹配二字) 例子 匹配值示例 ^ 文本开始字符 '^b'匹配以字母b开头的字符串 book, big, banana, bike $ 文本结束字符 'st$'匹配以st结尾的字符串 test, resist, persist . 任何单个字符 'b.t'匹配任何b和t之间有一个字符 bit, bat, but, bite * 0个或多个在它前面的字符

命令行下更好显示 postgresql 的查询结果

之前在用 mysql 的时候发现,当列数特别多的时候,在 linux 命令行下,显示不太友好, 然后可以通过将 sql 末尾的 ":" 改为 "\G" 来处理,详情看 命令行下更好显示 mysql 查询结果: 后面用 postgresql 自然就会想有没有类似的功能,果然: 执行 sql 之前,先输入 "\x" 即可, 开启后再查询就变成如下效果: 再次输入 "\x" 时则关闭当前模式 原文地址:https://www.cnb

Java,PostgreSQL时间范围查询

遇到一坑:对于如下代码 select * from order_mileagefuel where date > '2015-11-1' and date< '2015-11-5' 在PostgreSQL的客户端中执行时能得到结果,但在Java中执行时(此时时间范围是参数,类型为String),如date >=#{startDay} and date <=#{endDay} 执行时报如下错误:(而对于MySQL,在代码中却是能够正确执行的.) ERROR: operator doe

PostgreSQL锁查询与杀掉进程说明

查询表中存在的锁 select a.locktype,a.database,a.pid,a.mode,a.relation,b.relname from pg_locks a join pg_class b on a.relation = b.oid where upper(b.relname) = 'TABLE_NAME'; 以上为查询某表上是否存在锁的SQL语句. 查到后发现确实存在锁,如下: locktype | database |  pid  |      mode       | r

mysql简单的正则表达式查询

正则表达式是为复杂搜索指定模式的强大方式. MySQL采用Henry Spencer的正则表达式实施,其目标是符合POSIX 1003.2. 匹配以弄个数字开头的字符串 SELECT * FROM `gms_customer` where mobile REGEXP '^[0-9]'; 匹配包含-的字符串,有点类似 like %-% 特殊字符一般使用  \\-  \\.  \\为前导,进行转移的作用 select * from gms_customer where mobile REGEXP '

postgresql 导出查询结果

psql database_tst //将查询语句写入文件 database_tst=#>\w /tmp/write.txt database_tst=#>select * from views; //将查询结果写入文件 database_tst=#>\o /tmp/write.txt database_tst=#>select * from views; //列状显示 database_tst=#>\x database_tst=#>select * from vie

一步一步跟我学习lucene(15)---lucene搜索之正则表达式查询RegExQuery和手机邮箱查询示例

今天快下班的时候收到了一个群友的问题,大意是读取文本文件中的内容,找出文件中的手机号和邮箱,我自己写了一个读取文档的内容的正则查询示例,用于匹配文件中是否含有邮箱或者手机号,这个等于是对之前的文本处理工具的一个梳理,同时结合lucene内部提供的正则匹配查询RegexQuery: 废话不多说了,直接上代码,这里先对文件内容读取分类处理,分为pdf word excel 和普通文本四类,不同的种类读取文本内容不一样 pdf利用pdfbox读取内容,word和excel利用poi进行读取内容,文本文