在MYSQL中使用正则表达式的笔记

正则表达式不只是可以在php,asp,.net这些编辑脚本中使用了,在mysql中正则表达式也是可以使用的,下面我们一起来学习一下mysql中正则表达式使用方法.

正则表达式广泛用于各种程序编程的地方,在mysql sql语句中使用正则表达式也可以解决很多查询问题,化繁为简,并且巧妙运用可以提高mysql查询效率,本文讲讲mysql中如何使用regexp语法运行含有正则表达式的sql语句.

  1. SELECT prod_name
  2. FROM products
  3. WHERE prod_name REGEXP '1000|2000'
  4. ORDER BY prod_name;

在mysql中sql语句使用正则表达式,在需要的地方用REGEXP关键字,如例中所示,REGEXP正则表达式是’1000|2000’,表示1000或者2000,也就是查询prod_name字段为1000或者2000的结果.

mysql中的正则表达式规则大致和其他地方的正则表达式规则相同,比如“\”转义,“|”或者,字母、数字的表示都相同.

再如:

  1. SELECT prod_name
  2. FROM products
  3. WHERE prod_name REGEXP '\\([0-9] sticks?\\)'
  4. ORDER BY prod_name;

可以查到的结果例如:

(1 sticks)

(3 sticks)

(4)

说明:”\(“,”\)”表示转义,包含”(“,”)”.问号表示可有可无.

一个正则表达式中的可以使用以下保留字.

  1. ^
  2. 所匹配的字符串以后面的字符串开头
  3. mysql> select "fonfo" regexp "^fo$"; -> 0(表示不匹配)
  4. mysql> select "fofo" regexp "^fo"; -> 1(表示匹配)
  5. $
  6. 所匹配的字符串以前面的字符串结尾
  7. mysql> select "fono" regexp "^fono$"; -> 1(表示匹配)
  8. mysql> select "fono" regexp "^fo$"; -> 0(表示不匹配)
  9. .
  10. 匹配任何字符(包括新行)
  11. mysql> select "fofo" regexp "^f.*"; -> 1(表示匹配)
  12. mysql> select "fonfo" regexp "^f.*"; -> 1(表示匹配)
  13. a*
  14. 匹配任意多个a(包括空串)
  15. mysql> select "ban" regexp "^ba*n"; -> 1(表示匹配)
  16. mysql> select "baaan" regexp "^ba*n"; -> 1(表示匹配)
  17. mysql> select "bn" regexp "^ba*n"; -> 1(表示匹配)
  18. a+
  19. 匹配任意多个a(不包括空串)
  20. mysql> select "ban" regexp "^ba+n"; -> 1(表示匹配)
  21. mysql> select "bn" regexp "^ba+n"; -> 0(表示不匹配)
  22. a?
  23. 匹配一个或零个a
  24. mysql> select "bn" regexp "^ba?n"; -> 1(表示匹配)
  25. mysql> select "ban" regexp "^ba?n"; -> 1(表示匹配)
  26. mysql> select "baan" regexp "^ba?n"; -> 0(表示不匹配)
  27. de|abc
  28. 匹配de或abc
  29. mysql> select "pi" regexp "pi|apa"; -> 1(表示匹配)
  30. mysql> select "axe" regexp "pi|apa"; -> 0(表示不匹配)
  31. mysql> select "apa" regexp "pi|apa"; -> 1(表示匹配)
  32. mysql> select "apa" regexp "^(pi|apa)$"; -> 1(表示匹配)
  33. mysql> select "pi" regexp "^(pi|apa)$"; -> 1(表示匹配)
  34. mysql> select "pix" regexp "^(pi|apa)$"; -> 0(表示不匹配)
  35. (abc)*
  36. 匹配任意多个abc(包括空串)
  37. mysql> select "pi" regexp "^(pi)*$"; -> 1(表示匹配)
  38. mysql> select "pip" regexp "^(pi)*$"; -> 0(表示不匹配)
  39. mysql> select "pipi" regexp "^(pi)*$"; -> 1(表示匹配)
  40. {1}
  41. {2,3}
  42. 这是一个更全面的方法,它可以实现前面好几种保留字的功能
  43. a*
  44. 可以写成a{0,}
  45. a+
  46. 可以写成a{1,}
  47. a?
  48. 可以写成a{0,1}

在{}内只有一个整型参数i,表示字符只能出现i次,在{}内有一个整型参数i,后面跟一个“,”,表示字符可以出现i次或i次以上,在{}内只有一个整型参数i,后面跟一个“,”,再跟一个整型参数j,表示字符只能出现i次以上,j次以下(包括i次和j次),其中的整型参数必须大于等于0,小于等于 re_dup_max(默认是255),如果有两个参数,第二个必须大于等于第一个.

  1. [a-dx]
  2. 匹配“a”、“b”、“c”、“d”或“x”
  3. [^a-dx] --phpfensi.com
  4. 匹配除“a”、“b”、“c”、“d”、“x”以外的任何字符。“[”、“]”必须成对使用
  5. mysql> select "axbc" regexp "[a-dxyz]"; -> 1(表示匹配)
  6. mysql> select "axbc" regexp "^[a-dxyz]$"; -> 0(表示不匹配)
  7. mysql> select "axbc" regexp "^[a-dxyz]+$"; -> 1(表示匹配)
  8. mysql> select "axbc" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)
  9. mysql> select "gheis" regexp "^[^a-dxyz]+$"; -> 1(表示匹配)
  10. mysql> select "gheisa" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)
  11. ------------------------------------------------------------
  12. [[.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中的字符也不能是下划线.

  1. mysql> select "a word a" regexp "[[::]]"; -> 1(表示匹配)
  2. mysql> select "a xword a" regexp "[[::]]"; -> 0(表示不匹配)
  3. mysql> select "weeknights" regexp "^(wee|week)(knights|nights)$"; -> 1(表示匹配)

这就是在mysql中使用正则表达式的基本用法.