Mysql中正则表达式Regexp常见用法


当前第2页 返回上一页

· ‘.'匹配任何单个的字符。
· 字符类“[...]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的范围,使用一个“-”。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。
· “ * ”匹配零个或多个在它前面的字符。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配任何数量的数字,而“.*”匹配任何数量的任何字符。
如果REGEXP模式与被测试值的任何地方匹配,模式就匹配(这不同于LIKE模式匹配,只有与整个值匹配,模式才匹配)。
为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。
为了找出以“b”开头的名字,使用“^”匹配名字的开始:
使用正则

SELECT * FROM pet WHERE name REGEXP BINARY ‘^b';
SELECT * FROM pet WHERE name REGEXP ‘fy$';
SELECT * FROM pet WHERE name REGEXP ‘w';
SELECT * FROM pet WHERE name REGEXP ‘^…..$';
SELECT * FROM pet WHERE name REGEXP ‘^.{5}$';

今天在应用中遇到了这样的一个问题,

有一个字段 t1,其中的值类似于:1,1,1,2,3,3,4,4,5,5,2,4,3,2,1,2
需要从里面搜索出比如说:第一个逗号前的数字范围为3-5之间,第三个逗号前的数字的范围为3-5之间,第10个逗号前的数字范围为3-5之间,其余的都为1-5之间。。。
则sql语句可以这么写:

SELECT * FROM tb WHERE t1 REGEXP '^[3-5],[1-5],[3-5],[1-5],[1-5],[1-5],[1-5],[1-5],[1-5],[3-5],[1-5],[1-5],[1-5],[1-5],[1-5],[1-5]%';

1. 使用LIKE和NOT LIKE比较操作符(注意不能使用=或!=);
2. 模式默认是忽略大小写的;
3. 允许使用”_”匹配任何单个字符,”%”匹配任意数目字符(包括零字符);

附一些mysql正则规则

^ 匹配字符串的开始部分
$ 匹配字符串的结束部分
. 匹配任何字符(包括回车和新行)
a* 匹配0或多个a字符的任何序列
a+ 匹配1个或多个a字符的任何序列
a? 匹配0个或1个a字符
de|abc 匹配序列de或abc
(abc)* 匹配序列adc的0个或者多个实例

{n}、{m,n} {n}或{m,n}符号提供了编写正则表达式的更通用方式,能够匹配模式的很多前述原子(或“部分”)。m和n均为整数。
a* 可被写为a{0,}
a+ 可被写为a{1,}
a? 可被写为a{0,1}

[a-dX] 匹配任何是a,b,c,d或者X的字符,两个其他字符之间的'-'字符构成一个范围
[^a-dX] 匹配任何不是a,b,c,d或者X的字符,前面的字符'^'是否定的意思

[.characters.] 在括号表达式中(使用[和]),匹配用于校对元素的字符序列,字符为单个字符或新行等字符名
mysql> SELECT ‘~' REGEXP ‘[[.~.]]'; -> 1
mysql> SELECT ‘~' REGEXP ‘[[.tilde.]]'; -> 1

[=character_class=]
在括号表达式中(使用[和]),[=character_class=]表示等同类。它与具有相同校对值的所有字符匹配,包括它本身,
[[=a=]] 等同于[a(+)],[a+],[a{1,}]

[:character_class:]
在括号表达式中(使用[和]),[:character_class:]表示与术语类的所有字符匹配的字符类。

标准的类名称是:

alnum 文字数字字符
alpha 文字字符
blank 空白字符
cntrl 控制字符
digit 数字字符
graph 图形字符
lower 小写文字字符
print 图形或空格字符
punct 标点字符
space 空格、制表符、新行、和回车
upper 大写文字字符
xdigit 十六进制数字字符

[[:<:]], [[:>:]]

这些标记表示word边界。它们分别与word的开始和结束匹配。word是一系列字字符,其前面和后面均没有字字符。字符是alnum类中的字母数字字符或下划线(_)。

mysql> select ‘fang shan zi' regexp ‘[[:<:]]shan[[:>:]]'; -> 1
mysql> select ‘fang shan zi' regexp ‘[[:<:]]fang[[:>:]]'; -> 1
mysql> select ‘fang shans zi' regexp ‘[[:<:]]shan[[:>:]]'; -> 0

正则表达式使用特殊字符,应在其前面加上2个反斜杠''字符

mysql> SELECT '1+2′ REGEXP '1+2′; -> 0
mysql> SELECT '1+2′ REGEXP '1+2′; -> 0
mysql> SELECT '1+2′ REGEXP '1\+2′; -> 1

MySQL 查寻条件使用正则 regexp

我用的是 Mybatis

t.hobby : 条件字段
hobby : 查寻参数,值可以是多个逗号分隔的值:‘阅读,交友,围棋'

<!-- t.hobby 的值最初可能是这样: '    吃,  喝,嫖,赌  , 抽,坑,蒙,拐,骗,偷 ' 每个词的两边有空格不规则 -->
<!-- 下面逐步演示 -->
<if test="hobby!=null and hobby!=''">
 concat(',',REPLACE (t.hobby, ' ', ''),',') regexp concat(',(',replace(#{hobby},',','|'),'),')
</if>
<!-- 表字段 t.hobby 取出值 -->
<if test="hobby!=null and hobby!=''">
 concat(',',REPLACE ('    吃,  喝,嫖,赌  , 抽,坑,蒙,拐,骗,偷 ', ' ', ''),',') regexp concat(',(',replace(#{hobby},',','|'),'),')
</if>
<!-- 表字段值处理后,去掉了多余的空格 -->
<if test="hobby!=null and hobby!=''">
 concat(',','吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷',',') regexp concat(',(',replace(#{hobby},',','|'),'),')
</if>
<!-- concat后得到一个字符串,首尾加上了逗号 -->
<if test="hobby!=null and hobby!=''">
 ',吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷,' regexp concat(',(',replace(#{hobby},',','|'),'),')
</if>
<!-- 取出参数 #{hobby} 的值 -->
<if test="hobby!=null and hobby!=''">
 ',吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷,' regexp concat(',(',replace('吃,喝,嫖,嫖',',','|'),'),')
</if>
<!-- 把逗号换成 |  -->
<if test="hobby!=null and hobby!=''">
 ',吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷,' regexp concat(',(','吃|喝|嫖|嫖','),')
</if>
<!-- concat后得到一个字符串,首尾加上了括号,逗号  -->
<if test="hobby!=null and hobby!=''">
 ',吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷,' regexp ',(吃|喝|嫖|嫖),' <!-- 纪念于谦老师不赌的美德 -->
</if>

得到结果是 1 作为条件就是真了。

复杂的过程主要是用来处理查寻条件。得到符合要求的正则作条件就ok了
但个人觉得,更理想的方式是:
被查寻字段在当初存入数据时就处理好格式:'吃,喝,嫖,赌,抽,坑,蒙,拐,骗,偷'
查寻条件可以处理好传进来:',(吃|喝|嫖|嫖),'
那么一个查寻就可以简化成这样

<if test="hobby!=null and hobby!=''">
 concat(',', t.hobby ,',') regexp #{hobby}
</if>

到这就差不多了,基本上就可以看得懂了,实在不行就参考下面的相关文章。

更多SQL内容来自木庄网络博客


打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...