在MYSQL中使用正则表达式的笔记
正则表达式不只是可以在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.com
- 匹配除“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中使用正则表达式的基本用法.