好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

在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测试数据   匹配除[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中使用正则表达式的笔记的详细内容...

  阅读:52次