\\纵向制表
注意:为了匹配\本身,需要使用\\\a*
可以写成a{0,}
a+
可以写成a{1,}
a?
可以写成a{0,1}
[[:digit:]]{4}匹配连在一起的任意4位数字,当然,上面的例子也可以这样写REGEXP '[0-9][0-9][0-9][0-9]'
SELECT name FROM tab1 WHERE name REGEXP 'a*'; 匹配0个和多个a
通过使用这些定位符,能够使REGEXP起类似LIKE的作用
查询找到所有的名字以'st'开头
1
|
mysql>
SELECT
name
FROM
person_tbl
WHERE
name
REGEXP
'^st'
;
|
查询找到所有的名字以'ok'结尾
1
|
mysql>
SELECT
name
FROM
person_tbl
WHERE
name
REGEXP
'ok$'
;
|
查询找到所有的名字包函'mar'的字符串
1
|
mysql>
SELECT
name
FROM
person_tbl
WHERE
name
REGEXP
'mar'
;
|
查询找到所有名称以元音开始和'ok'结束 的
1
|
mysql>
SELECT
name
FROM
person_tbl
WHERE
name
REGEXP
'^[aeiou]|ok$'
;
|
一个正则表达式中的可以使用以下保留字
^
所匹配的字符串以后面的字符串开头
1
2
|
mysql>
select
"fonfo"
REGEXP
"^fo$"
; -> 0(表示不匹配)
mysql>
select
"fofo"
REGEXP
"^fo"
; -> 1(表示匹配)
|
$
所匹配的字符串以前面的字符串结尾
1
2
3
|
mysql>
select
"fono"
REGEXP
"^fono$"
; -> 1(表示匹配)
mysql>
select
"fono"
REGEXP
"^fo$"
; -> 0(表示不匹配)
.
|
匹配任何字符(包括新行)
1
2
|
mysql>
select
"fofo"
REGEXP
"^f.*"
; -> 1(表示匹配)
mysql>
select
"fonfo"
REGEXP
"^f.*"
; -> 1(表示匹配)
|
a*
匹配任意多个a(包括空串)
1
2
3
|
mysql>
select
"Ban"
REGEXP
"^Ba*n"
; -> 1(表示匹配)
mysql>
select
"Baaan"
REGEXP
"^Ba*n"
; -> 1(表示匹配)
mysql>
select
"Bn"
REGEXP
"^Ba*n"
; -> 1(表示匹配)
|
a+
匹配任意多个a(不包括空串)
1
2
|
mysql>
select
"Ban"
REGEXP
"^Ba+n"
; -> 1(表示匹配)
mysql>
select
"Bn"
REGEXP
"^Ba+n"
; -> 0(表示不匹配)
|
a?
匹配一个或零个a
1
2
3
|
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
1
2
3
4
5
6
|
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(包括空串)
1
2
3
|
mysql>
select
"pi"
REGEXP
"^(pi)*$"
; -> 1(表示匹配)
mysql>
select
"pip"
REGEXP
"^(pi)*$"
; -> 0(表示不匹配)
mysql>
select
"pipi"
REGEXP
"^(pi)*$"
; -> 1(表示匹配)
|
[a-dX]
匹配“a”、“b”、“c”、“d”或“X”
[^a-dX]
匹配除“a”、“b”、“c”、“d”、“X”以外的任何字符。
“[”、“]”必须成对使用
1
2
3
4
5
6
|
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(表示不匹配)
|