在MySQL中,模糊搜索的时候主要用两种方式:

1.like
2.regexp + 正则表达式 性能优于like


  正则表达式描述了一组字符串。

  •   最简单的正则表达式是不含任何特殊字符的正则表达式。例如,正则表达式hello匹配hello。
  •   非平凡的正则表达式采用了特殊的特定结构,从而使得它们能够与1个以上的字符串匹配。例如,正则表达式hello|word匹配字符串hello或字符串word。
  •   作为一个更为复杂的示例,正则表达式B[an]*s匹配下述字符串中的任何一个:Bananas,Baaaaas,Bs,以及以B开始、以s结束、并在其中包含任意数目a或n字符的任何其他字符串。

  例子:

    邮箱格式: '^[A-Z0-9._%-]+@[A-Z0-9.-]+.[A-Z]{2,4}$'

  主要使用的操作符如下:

  

1.(^)字符

  匹配字符串的开始位置,如“^a”表示以字母a开头的字符串。

SELECT 'xxxxyy' REGEXP '^xx';

2.($)字符

  匹配字符串的结束位置,如“X^”表示以字母X结尾的字符串。

SELECT 'xxxxyy' REGEXP 'Y$'; # 不区分大小写
SELECT 'xxxxyy' REGEXP 'y$';

3.(.)字符

  这个字符就是英文下的点,它匹配任何一个字符,包括回车、换行等。

4.(*)字符

  星号匹配0个或多个字符,在它之前必须有内容。

SELECT 'xxxxyy' REGEXP 'x*';

5.(+)字符

  匹配1个或多个字符,在它之前也必须有内容。加号跟星号的用法类似,只是星号允许出现0次,加号则必须至少出现一次。

6.(?)字符

  问号匹配0次或1次。


  其他实例:

# 以"举报"开头
SELECT * FROM rep_require WHERE order_title REGEXP '^举报'; # 以"问题"结尾
SELECT * FROM rep_require WHERE order_title REGEXP '问题$'; # 包含"无照经营"字符串
SELECT * FROM rep_require WHERE order_title REGEXP '无照经营'; # 以a-z开头 或者 ok结尾
SELECT * FROM rep_require WHERE order_title REGEXP '^[a-z]|ok$';
SELECT 'fonfo' REGEXP '^fo$'; # -- 字符串完全等于fo 定义了开头和结尾
SELECT 'fonfo' REGEXP '^fo.+fo$'; # -- fo开头 中间包含至少1个字符 fo结尾
SELECT 'fonfo' REGEXP '^fo.*fo$'; # -- . 不用加[] fo开头 fo结尾 中间随意
SELECT 'fofo' REGEXP '^fo$'; # -- 不行
SELECT 'fofo' REGEXP '^f.*'; # -- f开头 后面随意 0个或者无数个
SELECT 'Ban' REGEXP '^Ba*n';  # -- 以B开头 任意几个a 再n
SELECT 'Baaaaan' REGEXP '^Ba*n'; # -- 同上
SELECT 'Bn' REGEXP '^Ba*n'; # -- 同上 SELECT 'Ban' REGEXP '^Ba+n'; # # -- 至少一个a
SELECT 'Bn' REGEXP '^Ba+n'; # -- 不行 没有a 匹配不到 SELECT 'Ban' REGEXP '^Ba?n'; # -- 0个a 或者 1个a
SELECT 'Bn' REGEXP '^Ba?n'; # -- 同上
SELECT 'Baaaan' REGEXP '^Ba?n'; # -- 同上
# pi 或者 apa 规定了^$ 就必须完全相等才能匹配得到
SELECT 'pi' REGEXP 'pi|apa';
SELECT 'axe' REGEXP 'pi|apa';
SELECT 'apa' REGEXP 'pi|apa';
SELECT 'apa' REGEXP '^(pi|apa)$';
SELECT 'pi' REGEXP '^(pi|apa)$';
SELECT 'pix' REGEXP '^(pi|apa)$';
# 多个pi匹配
SELECT 'pi' REGEXP '^(pi)*$';
SELECT 'pip' REGEXP '^(pi)*$';
SELECT 'pipi' REGEXP '^(pi)*$';

特殊写法:{1} {1,} {2,3} 

  • 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)。

  如果有两个参数,第二个必须大于等于第一个。

# {1} {1,} {2,3} 写法
SELECT 'xxx' REGEXP 'x{4}'; # 4个x
SELECT 'aXbc' REGEXP '[a-dXYZ]'; # 匹配“a”、“b”、“c”、“d”或“X”
SELECT 'aXbc' REGEXP '^[a-dXYZ]$';
SELECT 'aXbc' REGEXP '^[a-dXYZ]+$';
SELECT 'aXbc' REGEXP '^[^a-dXYZ]+$'; # 匹配除“a”、“b”、“c”、“d”、“X”以外的任何字符。
SELECT 'gheis' REGEXP '^[^a-dXYZ]+$';
SELECT 'gheisa' REGEXP '^[^a-dXYZ]+$';
# “[”、“]”必须成对使用

END 2018-06-01 13:17:19

MySQL学习笔记:regexp正则表达式的更多相关文章

  1. MySql学习笔记(一) —— 正则表达式的使用

    前面介绍利用一些关键字搭配相应的SQL语句进行数据库查找过滤,但随着过滤条件的复杂性的增加,where 子句本身的复杂性也会增加.这时我们就可以利用正则表达式来进行匹配查找. 1.基本字符匹配 ' o ...

  2. MySql学习笔记(二) —— 正则表达式的使用

    前面介绍利用一些关键字搭配相应的SQL语句进行数据库查找过滤,但随着过滤条件的复杂性的增加,where 子句本身的复杂性也会增加.这时我们就可以利用正则表达式来进行匹配查找. 1.基本字符匹配 ' o ...

  3. mysql basic operation,mysql总结,对mysql经常使用语句的详细总结,MySQL学习笔记

    mysql> select * from wifi_data where dev_id like "0023-AABBCCCCBBAA" ; 1.显示数据库列表.show d ...

  4. 【mysql学习笔记整理】

    /*mysql学习笔记整理*/ /*常用的数据库操作对象*/ #库的操作#创建#数据库的创建USE mysql;CREATE DATABASE db_x;#删除#删除数据库DROP DATABASE ...

  5. Mysql学习笔记(三)对表数据的增删改查。

    正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...

  6. MySQL学习笔记一

    MySQL 学习笔记 一 一.数据库简单介绍 1. 按照数据库的发展时间顺序,主要出现了以下类型数据库系统: Ø 网状型数据库 Ø 层次型数据库 Ø 关系型数据库 Ø 面向对象数据库 上面4中数据库系 ...

  7. Mysql学习笔记(二)数据类型 补充

    原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...

  8. Mysql学习笔记(一)数据类型

    原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型     Mysql数据类型             含义(有符号)     tinyint(m ...

  9. 初识mysql学习笔记

    使用VMVirtualBox导入Ubuntu后,可以通过sudo apt-get install mysql-server命令下载mysql. 在学习过程中,我遇到了连接不上Xshell的问题.最终在 ...

  10. MySQL学习笔记-锁相关话题

    在事务相关话题中,已经提到事务隔离性依靠锁机制实现的.在本篇中围绕着InnoDB与MyISAM锁机制的不同展开,进而描述锁的实现方式,多种锁的概念,以及死锁产生的原因.   Mysql常用存储引擎的锁 ...

随机推荐

  1. python学习(23)requests库爬取猫眼电影排行信息

    本文介绍如何结合前面讲解的基本知识,采用requests,正则表达式,cookies结合起来,做一次实战,抓取猫眼电影排名信息. 用requests写一个基本的爬虫 排行信息大致如下图 网址链接为ht ...

  2. linux命令总结之lsof命令

    简介 lsof(list open files)是一个列出当前系统打开文件的工具.在linux环境下,任何事物都以文件的形式存在,通过文件不仅仅可以访问常规数据,还可以访问网络连接和硬件.所以如传输控 ...

  3. NATS_09:NATS常见问题说明

    1. Request() 和 Publish() 之间的不同 Publish()发送一条消息到 gnatsd 服务,是使用它的地址作为一个 主题(subject),而 gnatsd 交付消息给所有注册 ...

  4. Java泛型底层源码解析-ArrayList,LinkedList,HashSet和HashMap

    声明:以下源代码使用的都是基于JDK1.8_112版本 1. ArrayList源码解析 <1. 集合中存放的依然是对象的引用而不是对象本身,且无法放置原生数据类型,我们需要使用原生数据类型的包 ...

  5. Java基础-线程操作共享数据的安全问题

    Java基础-线程操作共享数据的安全问题 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.引发线程安全问题 如果有多个线程在同时运行,而这些线程可能会同时运行这段代码.程序每次运 ...

  6. js检测上传文件大小

    前言: 项目中经常用到需要上传文件.照片等功能,同时需要限制所上传文件的大小.很多插件都会采用后台请求验证,前端Js校验比较少.本篇介绍一个前端JS便捷判断上传文件大小的方法. 代码很简单,关键就是怎 ...

  7. 【转】java格式化输出 printf 例子

    [转]java格式化输出 printf 例子 转自http://www.cnblogs.com/TankMa/archive/2011/08/20/2146913.html#undefined imp ...

  8. HDU 1160 FatMouse's Speed (最长上升子序列)

    题目链接 题意:n个老鼠有各自的重量和速度,要求输出最长的重量依次严格递增,速度依次严格递减的序列,n最多1000,重量速度1-10000. 题解:按照重量递增排序,找出最长的速度下降子序列,记录序列 ...

  9. Informatica学习:2、配置存储库服务和集成服务

    继续上一篇的1.安装介质的获取与安装,本文介绍服务端的存储库服务和集成服务的配置. 安装好Informatica的客户端和服务端后,需要登陆Administration Console,配置存储库服务 ...

  10. c++ new 和delete

    c++中new和delete的使用方法 new和delete运算符用于动态分配和撤销内存的运算符 new用法: 1.     开辟单变量地址空间 1)new int;  //开辟一个存放数组的存储空间 ...