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

六月 27, 2019 | views
Comments 0

正则表达式不只是可以在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中使用正则表达式的基本用法.



zend