在Mysql进行模糊处理和查询中,一般都是用 LIKE 和 NOT LIKE 表达式,使用 _ 进行单个字符匹配,使用 % 进行 0或多个字符的匹配;
以下为Sql模糊查询的常见用法:如下图所示
#查询以 1个随意字符 开头,以“徽”结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '_徽';
#查询以 0个或多个随意字符 开头,以“徽”结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '%徽';
#查询以“安” 开头,以 1个随意字符 结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '安_';
#查询以“安” 开头,以 0个或多个随意字符 结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '安%';
#查询以“安” 开头,中间1个随意字符 以“徽”结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '安_徽';
#查询以“安” 开头,中间0或多个随意字符 以“徽”结尾的省份
SELECT * FROM T_PRO_CITY WHERE province_name like '安%徽';
工作中 like 或 not like 模式无法满足我们的过滤需求,这时候就要用到 正则表达式进行匹配。
在正则表达式中 ^ 匹配字符串开始, $ 匹配字符串结束, . 匹配任意一个字符, .* 匹配0或多个任意字符,.+ 匹配 1 或多个任意字符 .?匹配0个或一个任意字符,| 是或者的意思: a|b 意思是匹配a或者b,满足一个条件就成立,(abc)* 匹配零个或者多个字符串 abc
#查询以“安”开头的省份
SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^安';
#查询以“区”结尾的省份
SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '区$';
#查询以“西藏自治”开头的,中间为 1或多个任意字符,以“区”结尾的省份:找不到数据
SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治.+区$';
#查询以“西藏自治”开头的,中间为 0或多个任意字符,以“区”结尾的省份
SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治.*区$';
#查询以“西藏自治”开头的,中间为 0或1个任意字符,以“区”结尾的省份
SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治.?区$';
#查询字符串是否以 A或者B 开头的
SELECT "HELLO WORLD" REGEXP '^A|B';
#查询字符串是否以 0或者多个 “HELLO ”开头的
SELECT "HELLO WORLD" REGEXP '^(HELLO)*';
{1}, {2,3} 表示匹配指定次数。{n} 和 {m,n} 提供一种更通用的编写正则表达式的方法,用于多次匹配前一个元素(或者一组元素)。m 和 n 都是整数。
a* 等价于 a{0,}。
a+ 等价于 a{1,}。
a? 等价于 a{0,1}。
进一步来说,a{n} 表示字符 a 出现了 n 次;a{n,} 表示字符 a 出现了 n 次以上;a{m,n} 表示字符 a 出现了 m 到 n 次,m 必须小于 n。
[a-dX] 匹配字符 a、b、c、d 或者 X,[^a-dX] 匹配非 a、b、c、d 或者 X 的其他字符。- 表示匹配两个字符之间的所有字符,例如 [0-9] 表示匹配任一数字。如果想要包含字符 ] 自身,它必须写在 [ 的后面;如果想要包含字符 - 自身,它必须是括号内的第一个或者最后一个字符。其他任何没有特殊意义的字符只匹配它自己。例如: