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

一、SQL模式(% ,_)

  SQL的模式匹配允许你使用“_”匹配任何单个字符,而“%”匹配任意数目字符(包括零个字符)。在MySQL中,SQL的模式缺省是忽略大小写的。

  注意:在你使用SQL模式时,你不能使用=或!=;而使用LIKE或NOT LIKE比较操作符。

  语法:SELECT 字段 FROM 表 WHERE 某字段 Like 条件

  其中关于条件,SQL提供了两种匹配模式:

  1、百分号(%):表示任意个或多个字符。可匹配任意类型和长度的字符。

  示例1:

SELECT * FROM character WHERE name LIKE ‘%孙%';
即匹配姓名为“孙行者”,“行者孙,“行者孙”等包含“孙”类型的数据

  示例2:

SELECT * FROM character WHERE name LIke '%孙%' and name like '%行%';
即匹配姓名为“孙行者”,“行者孙,“行者孙”等包含“孙”和“行”的数据

  示例3:

SELECT * FROM character WHERE name LIke '%孙%行%‘;
只能匹配姓名为“孙行者”等类似“...孙...行...”的数据

  2、下划线(_):表示任意单个字符。匹配单个任意字符,它常用来限制表达式的字符长度语句:(可以代表一个中文字符)

  示例1:

SELECT * FROM character WHERE name LIKE ‘_三_';
即匹配姓名为“..三..”类型的数据,前后均只有一个字符

  示例2:

SELECT * FROM character WHERE name LIKE ‘_三';
即匹配姓名类似“...三”类型的数据,前面有且只有一个字符

  

二、正则模式

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

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

  1、MySQL正则表达式仅仅使SQL语言的一个子集,可以匹配基本的字符、字符串。

select * from wp_posts where post_name REGEXP 'hello';
可以检索出列post_name中所有包含hello的行

  2、.匹配除\n之外的任意单个字符

select * from wp_posts where post_name REGEXP '.og';
注:.是正则表达式中的一个特殊字符。它表示匹配一个字符,因此bog,cog,dog等等都能匹配。

  注意:

  关于大小写的区分:MySQL中正则表达式匹配(从版本3.23.4后)不区分大小写。

  如果要区分大小写,应该使用BINARY关键字,例如:

where post_name REGEXP BINARY 'Hello .000'

  3、^匹配字符串开始位置,如查询所有姓王的人名

select name from 表名 where name REGEXP '^王';

  4、$匹配字符串结束位置,如查询所有姓名末尾是“明”的人名

select name from 表名 where name REGEXP '明$';

  5、进行OR匹配

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

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

select * from products where pro_id REGEXP '1000|2000';
这样就1000和2000都能匹配并返回,当然,使用多个|就可以匹配多个串

  6、[ ]匹配任何单一字符,是另一种形式的OR语句,可缩写的OR语句

  例如,匹配范围:[0123456789]可以匹配0到9,[1-4][4-9]也是合法的范围。

  此外,范围不一定只是数值的,[a-z]匹配任意字母字符。

  例如,查询出w/z/s开头的人的人名

SELECT prod_name FROM products WHERE prod_name REGEXP '^[wzs]';

  7、[^....]匹配不包含在[ ]的字符,如查询出chenmin之外的人名

SELECT prod_name FROM products WHERE prod_name REGEXP '^[wzs]';

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

  8、匹配特殊字符使用\\进行转义

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

(1)\\-   表示查找-
(2)\\. 表示查找.
(3)\\f 表示换页
(4)\\n 表示换行
(5)\\r 表示回车
(6)\\t 表示制表
(7)\\v 表示纵向制表

  注:为了匹配\本身,需要使用\\\

  9、匹配字符类

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

  10、匹配多个示例,关于重复元字符

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

  例子:

select prod_name from products where prod_name REGEXP '[[:DIGIT:]]{4}';
如前所述,[:digit:]匹配任意数字,因而它为数字的一个几何。
[[:digit:]]{4}匹配连在一起的任意4位数字,当然,上面的例子也可以这样写REGEXP '[0-9][0-9][0-9][0-9]'

  11、定位符

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

  注:like匹配整个串,而REGEXP匹配子串。

三、in查询

  叫in查询不是很合理,更合理的说法是:in其实和=类似,区别在于:=后面是一个值。in后面可以是多个值。

  示例1:

select * from role where name in("唐三");
即匹配姓名为“唐三”一行数据;

  示例2:

select * from role where name in("唐三","唐三藏");
即匹配姓名为“唐三”,“唐三藏”一行数据;

  示例3:

select * from role where name in("唐三","%行者%")
只匹配姓名为“唐三”一行数据;即in查询不支持模糊查询,如示例4

  示例4:

select * from role where name in("%行者%")
无匹配结果

  

四、like contact模糊查询

  CONCAT(str1,str2,…) 函数返回结果为连接参数产生的字符串。

select * from role where name like contact("%","三","%");
即匹配姓名为“唐三”,“唐三藏”等类型的数据数据;

  like contact模糊查询强大的地方在于可以对传进来的参数进行某查询,比如经前端提交上的数据,赋值给参数name,则可以select * from table where name like contact("%",${name},"%")

MySQL模糊匹配查询like、regexp、in的更多相关文章

  1. mysql学习2:模糊匹配查询like,regexp,in

    mysql模糊匹配查询like,regexp,in   摘要 内容比较简单,无摘要.   关键词 模糊查询  like  regexp  in  contact   正文 下图是示例用到的数据表信息 ...

  2. mysql模糊匹配like及批量替换replace

    1.mysql 模糊匹配 like 与 not like 用法 : SELECT * FROM `user` where `nickname` LIKE '%测试%' SELECT * FROM `u ...

  3. Mysql 模糊匹配和转义字符

    首先创建一个测试表: insert into test(tt) values('\\\\172.18.28.153'); 现在我想使用模糊匹配,查出以 “\\172” 开头的字符串. 需要使用like ...

  4. Oracle和Mysql中mybatis模糊匹配查询区别

    1.Oracle AND NAME LIKE '%'||#{name}||'%' 2.Mysql AND NAME LIKE "%"#{name}"%"

  5. mysql模糊匹配

    select * from tableName where column like ""; select * from tableName where column regexp ...

  6. Mysql 模糊匹配(字符串str中是否包含子字符串substr)

    1.LIKE 通常与 % 一同使用,类似于一个元字符的搜索.若substr不在str中,则返回0. 2.INSTR(str,substr) 返回字符串 str 中子字符串的第一次出现位置.若subst ...

  7. mySql一个字段的值模糊匹配多表多列的查询

    1.dao层/** * 分页查询点卡集合信息 * @param tid 游戏类型编号 * @param gid 游戏编号 * @param searchInfo 包括(点卡名称,游戏名称,点卡面值,游 ...

  8. 转:使用Mongo Connector和Elasticsearch实现模糊匹配

    原文来自于:http://www.csdn.net/article/2014-09-01/2821485-how-to-perform-fuzzy-matching-with-mongo-connec ...

  9. jq模糊匹配

    jq是一般程序员在前台开发的时候都会使用的技术,其中模糊匹配查询在动态添加标签的时候经常用到,这里我写出我经常用到的几个模糊匹配的方法.其中有:^(前缀).$(后缀).*(包含)例如有这样一段代码: ...

随机推荐

  1. 2019.03.26 bzoj4444: [Scoi2015]国旗计划(线段树+倍增)

    传送门 题意简述:现在给你一个长度为mmm的环,有nnn条互不包含的线段,问如果强制选第iii条线段至少需要用几条线段覆盖这个环,注意用来的覆盖的线段应该相交,即[1,3],[4,5][1,3],[4 ...

  2. 洛谷[LnOI2019]长脖子鹿省选模拟赛 简要题解

    传送门 听说比赛的时候T4T4T4标程锅了??? WTF换我时间我要写T3啊 于是在T4T4T4调半天无果的情况下260pts260pts260pts收场真的是tcltcltcl. T1 快速多项式变 ...

  3. Unity中AB资源打包简单的脚本

    脚本应该放在Editor文件夹下 using System.Collections; using System.Collections.Generic; using UnityEngine; usin ...

  4. [转]数据库中间件 MyCAT源码分析——跨库两表Join

    1. 概述 2. 主流程 3. ShareJoin 3.1 JoinParser 3.2 ShareJoin.processSQL(...) 3.3 BatchSQLJob 3.4 ShareDBJo ...

  5. UNIX笔记 第二天

    一.进程的退出: exit(3) _exit(2) atexit(3)  onexit(3) 二.进程资源的回收:wait(2) waitpid(2) 三.加载新的可执行程序: exec函数族 exe ...

  6. search

    |—search()—|—添加一个列表变量Expend,存储每个小格扩展时为第几步,可打印出 |                    |—打印运动表 |—A*—|— heuristic() |—Dy ...

  7. c++中的const与指针

    const修饰符 使用const修饰变量时,该变量的值不可修改,因此需要初始化. 例如 const int s = 0: 此时s为值不可变的变量. 那么基于此,当const修饰指针时的情况有三种: ( ...

  8. 《HTTP权威指南》5-Web服务器

    各种形状,风格,尺寸的Web服务器 Web服务器会对HTTP请求进行处理并提供响应.Web服务器有着不同的风格,形状和尺寸但是不管功能,外貌,风格有何差异,所有的Web服务器都能够接收请求资源的HTT ...

  9. .net反混淆脱壳工具de4dot的使用

    de4dot是一个开源的.net反混淆脱壳工具,是用C#编写的,介绍一下它的使用方法 首先 pushd 到de4dot.exe所在文件夹,然后调用 de4dot.exe  路径+dll名称 如果显示: ...

  10. 1分钟快速制作漂亮的H5本地记事本

    大家好,以前给大家分享过一个五步骤制作精美的HTML5时钟的文章,点击回顾<五步教你制作漂亮精致的HTML时钟>,还有<一分钟教你如何实现唯美的文字描边>:今天给大家分享一个用 ...