文档章节

使用MySQL正则表达式 __MySQL必知必会

Airship
 Airship
发布于 2016/03/04 16:59
字数 993
阅读 58
收藏 15

正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较。

MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据。

MySQL仅支持多数正则表达式实现的一个很小的子集。

----------------------

9.2.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'

 

9.2.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

Airship
粉丝 43
博文 994
码字总数 20464
作品 0
南京
高级程序员
私信 提问
Mysql必知必会(4):使用正则表达式搜索(REGEXP)

本文主要介绍如何在Mysql中使用正则表达式进行搜索。 正则表达式是一个非常大的内容,我会在之后专门写博客介绍,这里只是简介一些常用匹配模式 博客文章地址:http://weiya.me/item/59.htm...

星空幻颖
2017/02/05
0
0
5本数据库经典之作,没看过的都白学了!

  【IT168 评论】1、 《数据库系统实现》   内容简介:书中对数据库系统实现原理进行了深入阐述,并具体讨论了数据库管理系统的三个主要成分――存储管理器、查询处理器和事务管理器的实...

it168网站
2017/11/13
0
0
自学书籍.MySQL必知必会 - 好书推荐

图书封面: 书籍简介: MySQL是世界上最受欢迎的数据库管理系统之一,书中从介绍简单的数据检索开始,逐步深入一些复杂的内容,包括联结的使用,子查询,正则表达式和基于全文本的搜索,存储过程,游标...

满满李
2016/04/24
394
0
《MySQL必知必会》读书笔记(二) 8~14章

1、like 搜索模式:由字面值,通配符或两者组合构成的搜索条件。 like指示MySQL,后跟的搜索模式利用通配符匹配而不是直接相等匹配进行比较。 %表示任何字符出现任意次数: select prodid,pr...

一万
2016/02/06
129
0
MySQL快速入门

继恶补了C++基础之后,又来恶补MySQL了,花了将近一天的时间啃完了<MySQL必知必会>这本书,整理了有点糙的读书笔记。 1.SHOW语句的使用: 2.SELECT查询语句: 3.LIMIT子句限定显示结果行数:...

waffle930
2016/10/04
59
0

没有更多内容

加载失败,请刷新页面

加载更多

任正非对华为热点问题的回应亮了,终于知道华为为什么能扛过这一次的冲击!

任正非对华为热点问题的回应亮了,终于知道华为为什么能扛过这一次的冲击! 如果你是华为的老板,看到一条传遍网络的“美国封锁华为”、“华为禁令”的消息,你会怎么办? 昨天上午,华为创始...

forespider
47分钟前
2
0
Java HTTP 组件库选型看这篇就够了

最近项目需要使用 Java 重度调用 HTTP API 接口,于是想着封装一个团队公用的 HTTP client lib. 这个库需要支持以下特性: 连接池管理,包括连接创建和超时、空闲连接数控制、每个 host 的连...

Java面经
47分钟前
4
0
nginx 重启

在 nginx.config 配置目录下 输入命令: nginx -s reload 在 nginx 中,如果我修改了一个配置文件,或者新增了一个配置文件。按照群里网友的描述,我需要关闭 nginx,或者重启 nginx,比较麻...

MrBoyce
49分钟前
0
0
Cesium中级5 - Terrain 地形

Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ CesiumJS支持对与水流相关的海洋、湖泊和河流以及全球高分辨率地形进行流式处理和可视化。查看山峰、山谷...

Cesium中文网
今天
0
0
搭建jupyter+nginx服务

Tips:该文章面向Mac和centos用户,如果是Windows用户,请先安装虚拟机。 概述 Jupyter Notebook(此前被称为 IPython notebook)是一个交互式笔记本,支持运行 40 多种编程语言。 Jupyter ...

阿dai学长
今天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部