文档章节

msql 正则表达式

notAcoder
 notAcoder
发布于 2013/03/14 16:54
字数 1106
阅读 102
收藏 2

正则表达式定义了一个字符串的规则。最简单的正则表达式不包含任何保留字。例如,正则表达式hello只和字符串“hello”匹配。
一般的正则表达式使用了某些特殊的结构,所以它能匹配更多的字符串。例如,正则表达式hello|word既能匹配字符串“hello”也能匹配字符串 “word”。举一个更复杂一点的例子,正则表达式b[an]*s可以匹配字符串“bananas”、“baaaaas” 、“bs”以及其他任何以b开头以s结尾的字符串,中间可以包括任意个a和任意个n的组合。

一个正则表达式中的可以使用以下保留字
^
所匹配的字符串以后面的字符串开头
mysql> select "fonfo" regexp "^fo$"; -> 0(表示不匹配)
mysql> select "fofo" regexp "^fo"; -> 1(表示匹配)
$
所匹配的字符串以前面的字符串结尾
mysql> select "fono" regexp "^fono$"; -> 1(表示匹配)
mysql> select "fono" regexp "^fo$"; -> 0(表示不匹配)
.
匹配任何字符(包括新行)
mysql> select "fofo" regexp "^f.*"; -> 1(表示匹配)
mysql> select "fonfo" regexp "^f.*"; -> 1(表示匹配)
a*
匹配任意多个a(包括空串)
mysql> select "ban" regexp "^ba*n"; -> 1(表示匹配)
mysql> select "baaan" regexp "^ba*n"; -> 1(表示匹配)
mysql> select "bn" regexp "^ba*n"; -> 1(表示匹配)
a+
匹配任意多个a(不包括空串)
mysql> select "ban" regexp "^ba+n"; -> 1(表示匹配)
mysql> select "bn" regexp "^ba+n"; -> 0(表示不匹配)
a?
匹配一个或零个a
mysql> select "bn" regexp "^ba?n"; -> 1(表示匹配)
mysql> select "ban" regexp "^ba?n"; -> 1(表示匹配)
mysql> select "baan" regexp "^ba?n"; -> 0(表示不匹配)
de|abc
匹配de或abc
mysql> select "pi" regexp "pi|apa"; -> 1(表示匹配)
mysql> select "axe" regexp "pi|apa"; -> 0(表示不匹配)
mysql> select "apa" regexp "pi|apa"; -> 1(表示匹配)
mysql> select "apa" regexp "^(pi|apa)$"; -> 1(表示匹配)
mysql> select "pi" regexp "^(pi|apa)$"; -> 1(表示匹配)
mysql> select "pix" regexp "^(pi|apa)$"; -> 0(表示不匹配)
(abc)*
匹配任意多个abc(包括空串)
mysql> select "pi" regexp "^(pi)*$"; -> 1(表示匹配)
mysql> select "pip" regexp "^(pi)*$"; -> 0(表示不匹配)
mysql> select "pipi" regexp "^(pi)*$"; -> 1(表示匹配)
{1}
{2,3}
这是一个更全面的方法,它可以实现前面好几种保留字的功能
a*
可以写成a{0,}
a+
可以写成a{1,}
a?
可以写成a{0,1}
在{}内只有一个整型参数i,表示字符只能出现i次;在{}内有一个整型参数i,后面跟一个“,”,表示字符可以出现i次或i次以上;在{}内只有一个整型参数i,后面跟一个“,”,再跟一个整型参数j,表示字符只能出现i次以上,j次以下(包括i次和j次)。其中的整型参数必须大于等于0,小于等于 re_dup_max(默认是255)。如果有两个参数,第二个必须大于等于第一个
[a-dx]
匹配“a”、“b”、“c”、“d”或“x”
[^a-dx]
匹配除“a”、“b”、“c”、“d”、“x”以外的任何字符。“[”、“]”必须成对使用
mysql> select "axbc" regexp "[a-dxyz]"; -> 1(表示匹配)
mysql> select "axbc" regexp "^[a-dxyz]$"; -> 0(表示不匹配)
mysql> select "axbc" regexp "^[a-dxyz]+$"; -> 1(表示匹配)
mysql> select "axbc" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)
mysql> select "gheis" regexp "^[^a-dxyz]+$"; -> 1(表示匹配)
mysql> select "gheisa" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)
------------------------------------------------------------
[[.characters.]]
表示比较元素的顺序。在括号内的字符顺序是唯一的。但是括号中可以包含通配符, 所以他能匹配更多的字符。举例来说:正则表达式[[.ch.]]*c匹配chchcc的前五个字符。
[=character_class=]
表示相等的类,可以代替类中其他相等的元素,包括它自己。例如,如果o和(+)是一个相等的类的成员,那么[[=o=]]、[[=(+)=]]和[o(+)]是完全等价的。
[:character_class:]
在括号里面,在[:和:]中间是字符类的名字,可以代表属于这个类的所有字符。
字符类的名字有: alnum、digit、punct、alpha、graph、space、blank、lower、upper、cntrl、print和xdigit
mysql> select "justalnums" regexp "[[:alnum:]]+"; -> 1(表示匹配)
mysql> select "!!" regexp "[[:alnum:]]+"; -> 0(表示不匹配)
[[::]]
分别匹配一个单词开头和结尾的空的字符串,这个单词开头和结尾都不是包含在alnum中的字符也不能是下划线。
mysql> select "a word a" regexp "[[::]]"; -> 1(表示匹配)
mysql> select "a xword a" regexp "[[::]]"; -> 0(表示不匹配)
mysql> select "weeknights" regexp "^(wee|week)(knights|nights)$"; -> 1(表示匹配)
详细出处参考:http://www.jb51.net/article/15315.htm

© 著作权归作者所有

上一篇: 正则表达式
notAcoder
粉丝 5
博文 30
码字总数 12671
作品 0
巴南
架构师
私信 提问
TDSQL“相似查询工具MSQL+”入选VLDB论文

欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯云数据库 TencentDB发表于云+社区专栏 作者介绍:王晓宇,腾讯数据库TDSQL团队成员,目前参与TDSQL数据库内核研发工作...

腾讯云加社区
2018/10/18
0
0
datagrip连接本地mysql只显示information_schema数据库,不显示msql,sys,test数据库,如何解决?

datagrip连接本地mysql只显示information_schema数据库,不显示msql,sys,test数据库,如何解决?

罗祥
2017/02/14
1K
4
postgresql select as 问题

@kenyon_君羊 你好,想跟你请教个问题: 在msql中可以实现这样的查询: 结果如下: 但在postgresql 中如果使用dblink语法就会报错 错误信息:

Im胡子
2013/12/31
1K
1
数据量大,解决在线事物处理(OLTP),大家推荐一个解决方案吧,谢谢

我们公司数据量现在越来越多,关系型数据库以前用的sql server,为了降低成本和提高查询效率,我们要用开源的数据库。数据量大了,查询就会慢。现在不知道用什么数据库好。最好可以实现集群,...

小叮当_加V
2016/07/22
460
3
c3p0连接msql

@JFinal 你好,想跟你请教个问题:c3p0连接msql,root密码:FTslsqT2w3d4IIaOp;就不能连接,而改成123456就可以。请问为什么呢?

嘿真好
2013/12/12
683
1

没有更多内容

加载失败,请刷新页面

加载更多

无回路有向图的拓扑排序

因公司业务需要,在表单中每个字段都会配置自动计算,但自动计算公式中会引用到其他字段中的值。所以希望可以根据计算公式,优先计算引用的公式。所以最终使用了无回路有向图的扩扑排序来实现...

兜兜毛毛
今天
6
0
如何抢占云栖大会C位?史上最强强强攻略来了

点击观看视频: APSARA云栖大会开发者情怀 原文链接 本文为云栖社区原创内容,未经允许不得转载。

阿里云官方博客
今天
6
0
Kubernetes 从懵圈到熟练:集群服务的三个要点和一种实现

作者 | 声东 阿里云售后技术专家<br /> 文章来源:Docker,点击查看原文。 <br />以我的经验来讲,理解 Kubernetes 集群服务的概念,是比较不容易的一件事情。尤其是当我们基于似是而非的理解...

阿里巴巴云原生
今天
9
0
PHP7.3的新特性

2018年12月6日,PHP7.3正式版发布,在PHP7.2基础上进行了大量错误修复和安全优化,性能提升10%! 从目前的更新说明来看,PHP 7.3 并不是一个主打新特性的版本,包含更多的是 bug 修复。PHP 7...

迅睿CMS-PHP开源CMS程序
今天
8
0
Tomcat 应用中并行流带来的类加载问题

本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/f-X3n9cvDyU5f5NYH6mhxQ 作者:肖铭轩、王道环 随着 Java8 的不断流行,越来越多的开发人员使用并行流(parallel)...

vivo互联网技术
今天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部