SQL通配符

模糊查询与通配符冲突

表结构描述:当前有一张表,此处假定node_info,存在一个字段node_path是由 ‘字母’、‘数字’ 及 ‘下划线_’组成,如: abc_1_de_f
需求:查询所有node_path以‘ abc_’开头的记录

这个问题,自然而然的就想到,很简单,直接like % 模糊匹配就OK: 
  1. SELECT * FROM mode_info WHERE node_path LIKE 'abc_%'  
运行,发现结果根本就不对,远远超过预期。不仅abc_开头的被查出来,abcd开头等等的也被查询命中。后来想了一下,突然记起'_'是通配符,也就是通常所说的占位符。而通配符大家都知道,会匹配所有单一字符。所以也就意味着,上面的那个sql,会匹配到所有node_path长度大于等于4,且以abc开头的所有记录。
那么,上面的需求该怎么实现呢。很简单:只要避免‘_’在此处作为通配符存在即可。如何避免呢,那就需要用到另外一个通配符'[]'。修改sql:
  1. SELECT * FROM mode_info WHERE node_path LIKE 'abc[_]%'  
至此处,问题已解决。
下面简单介绍下SQL通配符。

SQL通配符

通配符主要以下几种: %_[][^]

1. %:模糊匹配一个或多个字符。如,以ab开头

  1. SELECT * FROM (  
  2.     SELECT 'abc_2sd_38u' 'a'  
  3.     UNION ALL  
  4.     SELECT 'bcf' 'a'  
  5. ) c  
  6. WHERE c.a LIKE 'ab%'  

a
-----------
abc_2sd_38u

2. _:占位符,匹配任意一个字符。如,以abc_开头

  1. SELECT * FROM (  
  2.     SELECT 'abc_2sd_38u' 'a'  
  3.     UNION ALL  
  4.     SELECT 'abcd_5d_3u' 'a'  
  5.     UNION ALL  
  6.     SELECT 'abc' 'a'  
  7. ) c  
  8. WHERE c.a LIKE 'abc[_]%'  
a
-----------
abc_2sd_38u

3. []:目标匹配字符:匹配单个字符,若写了多个,匹配任一。如,所有以1或者2开头的

  1. SELECT * FROM (  
  2.     SELECT '1_21' 'a'  
  3.     UNION ALL  
  4.     SELECT '121' 'a'  
  5.     UNION ALL  
  6.     SELECT '131' 'a'  
  7.     UNION ALL  
  8.     SELECT '142' 'a'  
  9.     UNION ALL  
  10.     SELECT '223' 'a'  
  11.     UNION ALL  
  12.     SELECT '324' 'a'  
  13. ) x  
  14. WHERE x.a LIKE '[12]%'  
a
-----------
1_21
121
131
142
223

4. [^]:目标匹配字符,[]相反。如,所有非1、2开头的

  1. SELECT * FROM (  
  2.     SELECT '1_21' 'a'  
  3.     UNION ALL  
  4.     SELECT '121' 'a'  
  5.     UNION ALL  
  6.     SELECT '131' 'a'  
  7.     UNION ALL  
  8.     SELECT '142' 'a'  
  9.     UNION ALL  
  10.     SELECT '223' 'a'  
  11.     UNION ALL  
  12.     SELECT '324' 'a'  
  13. ) x  
  14. WHERE x.a LIKE '[^12]%'  
a
-----------
324
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值