• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

Mysql的模糊查询和正则表达式

武飞扬头像
你是光芒丶
帮助1

在Mysql进行模糊处理和查询中,一般都是用 LIKENOT LIKE 表达式,使用 _ 进行单个字符匹配,使用 % 进行 0或多个字符的匹配;

以下为Sql模糊查询的常见用法:如下图所示

  1.  
    #查询以 1个随意字符 开头,以“徽”结尾的省份
  2.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '_徽';
  3.  
     
  4.  
    #查询以 0个或多个随意字符 开头,以“徽”结尾的省份
  5.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '%徽';
  6.  
     
  7.  
    #查询以“安” 开头,以 1个随意字符 结尾的省份
  8.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '安_';
  9.  
     
  10.  
    #查询以“安” 开头,以 0个或多个随意字符 结尾的省份
  11.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '安%';
  12.  
     
  13.  
    #查询以“安” 开头,中间1个随意字符 以“徽”结尾的省份
  14.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '安_徽';
  15.  
     
  16.  
    #查询以“安” 开头,中间0或多个随意字符 以“徽”结尾的省份
  17.  
    SELECT * FROM T_PRO_CITY WHERE province_name like '安%徽';
学新通

 工作中 like 或 not like 模式无法满足我们的过滤需求,这时候就要用到 正则表达式进行匹配。

在正则表达式中 ^ 匹配字符串开始, $ 匹配字符串结束,  . 匹配任意一个字符, .* 匹配0或多个任意字符,. 匹配 1 或多个任意字符    .?匹配0个或一个任意字符,| 是或者的意思: a|b 意思是匹配a或者b,满足一个条件就成立,(abc)* 匹配零个或者多个字符串 abc

  1.  
    #查询以“安”开头的省份
  2.  
    SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^安';
  3.  
     
  4.  
    #查询以“区”结尾的省份
  5.  
    SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '区$';
  6.  
     
  7.  
    #查询以“西藏自治”开头的,中间为 1或多个任意字符,以“区”结尾的省份:找不到数据
  8.  
    SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治. 区$';
  9.  
     
  10.  
    #查询以“西藏自治”开头的,中间为 0或多个任意字符,以“区”结尾的省份
  11.  
    SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治.*区$';
  12.  
     
  13.  
    #查询以“西藏自治”开头的,中间为 01个任意字符,以“区”结尾的省份
  14.  
    SELECT * FROM `T_PROVINCE` WHERE PRO_NAME REGEXP '^西藏自治.?区$';
  15.  
     
  16.  
    #查询字符串是否以 A或者B 开头的
  17.  
    SELECT "HELLO WORLD" REGEXP '^A|B';
  18.  
     
  19.  
    #查询字符串是否以 0或者多个 “HELLO ”开头的
  20.  
    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] 表示匹配任一数字。如果想要包含字符 ] 自身,它必须写在 [ 的后面;如果想要包含字符 - 自身,它必须是括号内的第一个或者最后一个字符。其他任何没有特殊意义的字符只匹配它自己。例如:
 

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhgfeiig
系列文章
更多 icon
同类精品
更多 icon
继续加载