正则表达式不只是可以在php,asp,.net这些编辑脚本中使用了,在mysql中正则表达式也是可以使用的,下面我们一起来学习一下mysql中正则表达式使用方法.
正则表达式广泛用于各种程序编程的地方,在mysql sql语句中使用正则表达式也可以解决很多查询问题,化繁为简,并且巧妙运用可以提高mysql查询效率,本文讲讲mysql中如何使用regexp语法运行含有正则表达式的sql语句.
SELECT prod_name FROM products WHERE prod_name REGEXP '1000|2000' ORDER BY prod_name;在mysql中sql语句使用正则表达式,在需要的地方用REGEXP关键字,如例中所示,REGEXP正则表达式是’1000|2000’,表示1000或者2000,也就是查询prod_name字段为1000或者2000的结果.
mysql中的正则表达式规则大致和其他地方的正则表达式规则相同,比如[\]转义,[|]或者,字母、数字的表示都相同.
再如:
SELECT prod_name FROM products WHERE prod_name REGEXP '\\([0-9] sticks?\\)' ORDER BY prod_name;可以查到的结果例如:
(1 sticks)
(3 sticks)
(4)
说明: ]\([,]\)]表示转义,包含]([,])].问号表示可有可无.
一个正则表达式中的可以使用以下保留字.
^ 所匹配的字符串以后面的字符串开头 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] --phpfensi测试数据 匹配除[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(表示匹配)这就是在mysql中使用正则表达式的基本用法.
查看更多关于在MYSQL中使用正则表达式的笔记的详细内容...