正则表达式用来描述或者匹配符合规则的字符串。它的用法和like比较相似,但是它又比like更强大,能够实现一些很特殊的规则匹配;正则表达式需要使用REGEXP命令,匹配上返回"1"匹配不上返回"0",默认不加条件REGEXP相当于like '%%'。在前面加上NOT相当于NOT LIKE
命令 | 说明 |
^ | 在字符的开启处进行匹配。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 '\n' 或 '\r' 之后的位置。 |
$ | 在字符的末尾处进行匹配。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 '\n' 或 '\r' 之前的位置。 |
. | 匹配除 "\n" 之外的任何单个字符。要匹配包括 '\n' 在内的任何字符,请使用像 '[.\n]' 的模式。 |
[….] | 字符集合。匹配所包含的任意一个字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'。 |
[m-n] | 匹配m到n之间的任意单个字符,例如[0-9],[a-z],[A-Z] |
[^..] | 负值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'。 |
* | 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等价于{0,}。 |
+ | 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。 |
a* | 匹配0个或多个a,包括空,可以作为占位符使用. |
a+ | 匹配一个或多个a,不包括空 |
a? | 匹配一个或0个a |
a1| a2 | 匹配a1或a2 |
a{m} | 匹配m个a |
a{m,} | 匹配m个或者更多个a |
a{m,n} | 匹配m到n个a |
a{,n} | 匹配0到n个a |
(….) | 将模式元素组成单一元素,例如(do)*意思是匹配0个多或多个do |
find_in_set相同功能的正则表达式
REGEXP CONCAT('^',#{item},'$|^',#{item},',|,',#{item},',','|,',#{item},'$')
特别要注意最后的()的命令,如果不使用()那么所有的都是指单个字符去做匹配,如果需要使用多个字符作为一个整体去匹配,就需要将多个字符使用()给括起来
结论:
1.使用REGEXP和NOT REGEXP操作符(类似LIKE和NOT LIKE);
2.REGEXP默认也是不区分大小写,可以使用BINARY关键词强制区分大小写; WHERE NAME REGEXP BINARY ‘^[A-Z]’;
3.REGEXP默认是部分匹配原则,即有一个匹配上则返回真。例如:SELECT 'Abc' REGEXP BINARY '[A-Z]';