• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MYSQL模式匹配:REGEXP跟like用法_mysql

mysql 搞代码 7年前 (2018-06-07) 226次浏览 已收录 0个评论

mysql模式匹配:REGEXP和like用法

like要求整个数据都要匹配,而REGEXP只需要部分匹配即可。 、

也就是说,用Like,必须这个字段的所有内容满足条件,而REGEXP只需要有任何一个片段满足即可。

 

MySQL提供标准的SQL模式匹配(like),以及一种基于象Unix实用程序如vi、grep和sed的扩展正则表达式模式匹配的格式(regexp)。

SQL的模式匹配允许你使用“_”匹配任何单个字符,而“%”匹配任意数目字符(包括零个字符)。在 MySQL中,SQL的模式缺省是忽略大小写的。下面显示一些例子。注意在你使用SQL模式时,你不能使用=或!=;而使用LIKE或NOT LIKE比较操作符。

 

 

为了找出以“b”开头的名字:
mysql> SELECT * FROM pet WHERE name LIKE “b%”;
+——–+——–+———+——+————+————+
| name | owner | species | sex | birth | death |
+——–+——–+———+——+————+————+
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
+——–+——–+———+——+————+————+

 

为了找出以“fy”结尾的名字:
mysql> SELECT * FROM pet WHERE name LIKE “%fy”;
+——–+——–+———+——+————+——-+
| name | owner | species | sex | birth | death |
+——–+——–+———+——+————+——-+
| Fluffy | Harold | cat | f | 1993-02-04 | NULL |
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
+——–+——–+———+——+————+——-+

 

为了找出包含一个“w”的名字:
mysql> SELECT * FROM pet WHERE name LIKE “%w%”;
+———-+——-+———+——+————+————+
| name | owner | species | sex | birth | death |
+———-+——-+———+——+————+————+
| Claws | Gwen | cat | m | 1994-03-17 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
| Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |
+———-+——-+———+——+————+————+

 

为了找出包含正好5个字符的名字,使用“_”模式字符:
mysql> SELECT * FROM pet WHERE name LIKE “_____”;
+——-+——–+———+——+————+——-+
| name | owner | species | sex | birth | death |
+——-+——–+———+——+————+——-+
| Claws | Gwen | cat | m | 1994-03-17 | NULL |
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
+——-+——–+———+——+————+——-+

另外一种匹配是基于正则表达式的。当你对这类模式进行匹配测试时,使用REGEXP和NOT REGEXP操作符(或RLIKE和NOT RLIKE,它们是同义词)。

 

“.”匹配任何单个的字符。
一个字符类“[…]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”、“b”或“c”。为了命名字符的一个范围,使用一个“-”。“[a-z]”匹配任何小写字母,而“[0-9]”匹配任何数字。
“ * ”匹配零个或多个在它前面的东西。例如,“x*”匹配任何数量的“x”字符,“[0-9]*”匹配的任何数量的数字,而“.*”匹配任何数量的任何东西。
正则表达式是区分大小写的,但是如果你希望,你能使用一个字符类匹配两种写法。例如,“[aA]”匹配小写或大写的“a”而“[a-zA-Z]”匹配两种写法的任何字母。

如果它出现在被测试值的任何地方,模式就匹配(只要他们匹配整个值,SQL模式匹配)。
为了定位一个模式以便它必须匹配被测试值的开始或结尾,在模式开始处使用“^”或在模式的结尾用“$”。
为了说明扩展正则表达式如何工作,上面所示的LIKE查询在下面使用REGEXP重写:

为了找出以“b”开头的名字,使用“^”匹配名字的开始并且“[bB]”匹配小写或大写的“b”:
mysql> SELECT * FROM pet WHERE name REGEXP “^[bB]”;
+——–+——–+———+——+————+————+
| name | owner | species | sex | birth | death |
+——–+——–+———+——+————+————+
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
+——–+——–+———+——+————+————+

 

为了找出以“fy”结尾的名字,使用“$”匹配名字的结尾:
mysql> SELECT * FROM pet WHERE name REGEXP “fy$”;
+——–+——–+———+——+————+——-+
| name | owner | species | sex | birth | death |
+——–+——–+———+——+————+——-+
| Fluffy | Harold | cat | f | 1993-02-04 | NULL |
| Buffy | Harold | dog | f | 1989-05-13 | NULL |
+——–+——–+———+——+————+——-+

 

为了找出包含一个“w”的名字,使用“[wW]”匹配小写或大写的“w”:
mysql> SELECT * FROM pet WHERE name REGEXP “[wW]”;
+———-+——-+———+——+————+————+
| name | owner | species | sex | birth | death |
+———-+——-+———+——+————+————+
| Claws | Gwen | cat | m | 1994-03-17 | NULL |
| Bowser | Diane | dog | m | 1989-08-31 | 1995-07-29 |
| Whistler | Gwen | bird | NULL | 1997-12-09 | NULL |
+———-+——-+———+——+————+————+

 

来源:http://www.webjx.com/database/mysql-32809.html

 

实例:

 

1. 本字符匹配

 

REGEXP后所跟的东西作为正则表达式处理。

SELECT prod_name FROM products WHERE prod_name REGEXP '1000' ORDER BY prod_name;  ------返回------ +------------------------+ |    prod_name    | +------------------------+ |  JetPack 1000  | +------------------------+

 

.  表示匹配任意一个字符。

SELECT prod_name FROM products WHERE prod_name REGEXP '.000' ORDER BY prod_name;  ------------返回-----------  +-------------------------+ |     prod_name    | +-------------------------+ |   JetPack 1000  | |   JetPack 2000  | +-------------------------+

 

MySQL中的正则表达式匹配不区分大小写。

为区分大小写,可使用BINARY关键字。

如:WHERE prod_name REGEXP BINARY ‘JetPack .000’

 
2. 进行OR匹配

为搜索两个串之一(或者这个串,或者为另一个串),使用 | 。

| 作为OR操作符,表示匹配其中之一。可给出两个以上的OR条件。

SELECT prod_name FROM products WHERE prod_name REGEXP '1000 | 2000' ORDER BY prod_name;  ------------返回------------  +----------------------+ |  prod_name   | +----------------------+ | JetPack 1000 | | JetPack 2000 | +----------------------+

 

[ ] 匹配任何单一字符。

[123]定义一组字符,意思是匹配1或2或3.

[ ]是另外一种形式的OR语句,[123] Ton  就是  [1 | 2 | 3] Ton 的缩写。

^ 否定一个字符集合,将匹配除指定字符外的任何东西。[^123]将匹配除这些字符外的任何东西。

SELECT prod_name FROM products WHERE prod_name REGEXP '[123] Ton' ORDER BY prod_name;  -------------返回------------  +--------------------+ | prod_name   | +--------------------+ | 1 ton anvil    | | 2 ton anvil    | +--------------------+

 

匹配范围

[0123456789] 或 [0-9] 将匹配数字0到9

[a-z] 匹配任意字母符号

SELECT prod_name FROM products WHERE prod_name REGEXP '[1-5] Ton' ORDER BY prod_name;  ----------返回-----------  +-------------------+ |  prod_name | +-------------------+ |  .5 ton anvil  | |  1 ton anvil   | |  2 ton anvil   | +-------------------+

 

匹配特殊字符

//  为前导。即转义.正则表达式内具有特殊意义的所有字符都必须以这种方式转义。

//-  表示查找 –

//.  表示查找 .

SELECT prod_name FROM vendors WHERE vend_name REGEXP '//.' ORDER BY vend_name;  -------------返回-------------  +----------------------+ |  vend_name   | +----------------------+ |  Furball Inc.    | +----------------------+

 

 

//  也用来引用元字符(具有特殊意义的字符)

//f    换页 //n    换行 //r    回车 //t    制表 //v    纵向制表

 

匹配字符类

[:a;num:]    任意字母和数字(同 [a-zA-Z0-9]) [:alpha:]     任意字符(同 [a-zA-Z]) [:blank:]     空格和制表(同 [//t]) [:cntrl:]        ASCII控制字符(ASCII 0到31和127) [:digit:]       任意数字(同[0-9]) [:graph:]    与["print:] 相同,但不包括空格 [:lower:]      任意小写字线(同 [a-z]) [:print:]        任意可打印字符 [:punct:]      既不在 [:alnum:] 又不在 [:cntrl:] 中的任意字符 [space:]       包括空格在内的任意空白字符(同 [//f//n//t//r//v]) [:upper:]     任意大小字母(同 [A-Z]) [:xdigit:]      任意十六进制数字(同 [a-fA-F0-9])

 

匹配多个实例

元字符              说明 *                       0个或多个匹配 +                      1个或多个匹配(等于 {1, }) ?                      0个或1个匹配(等于 {0, 1}) {n}                    指定数目的匹配 {n, }                  不少于指定数目的匹配 {n ,m}                匹配数目的范围(m不超过255)

 

以下例子:s后的?使s可选,因为?匹配它前面的任何字符的0次或1次出现。

SELECT prod_name FROM products WHERE prod_name REGEXP '//([0-9] sticks?//)' ORDER BY prod_name;  ------------返回------------  +-----------------------+ |  prod_name    | +-----------------------+ |  TNT (1 stick)   | |  TNT (5 sticks) | +-----------------------+

 

匹配连在一直的4位数字:WHERE prod_name REGEXP ‘[[:digit:]]{4}’
定位符

^         文本的开始 $        文本的末尾 [[:<:]]  词的开始 [[:>:]]  词的结尾

SELECT prod_name FROM products WHERE prod_name REGEXP '^[0-9//.]' ORDER BY prod_name;  -----------返回----------  +---------------------+ |   prod_name  | +---------------------+ |  .5 ton anvil   | |  1 ton anvil    | |  2 ton anvil    | +---------------------+

 

^的双重用途:在集合中(用[ ]定义),用它来否定该集合。否则,用来指串的开始和。

LIKE 匹配整个串,而REGEXP匹配子串。

    简单的正则表达式测试  可以在不使用数据库的情况下用SELECT来测试正则表达式。

    REGEXP检查总是返回0(没有匹配)或1(匹配),可以用带文字串的REGEXP来测

    试表达式,并试验它们。相应的语法如下:

        SELECT ‘hello’ REGEXP ‘[0-9]’

    这个例子返回0(因为文本hello中没有数字)。

 

原文:http://www.cnblogs.com/way_testlife/archive/2010/09/17/1829567.html

欢迎大家阅读《MYSQL模式匹配:REGEXP跟like用法_mysql》,跪求各位点评,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MYSQL模式匹配:REGEXP跟like用法_mysql

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址