【问题标题】:How to ignore characters on a MYSQL SELECT LIKE %...%如何忽略 MYSQL SELECT LIKE %...% 上的字符
【发布时间】:2012-04-08 15:52:06
【问题描述】:

我有一个带有phone 列的表格,其中数据可能在数字之间有空格、点、破折号或+ 号。 我需要使用忽略所有这些字符的 LIKE 通配符进行搜索,例如:

  • 记录的电话号码可能为“+123-456 78.90”
  • 按顺序查找“6789”或任何完整或不完整的正确数字序列的查询应显示该记录。

不幸的是,我无法清理原始表以删除非数字字符并执行普通的 SELECT LIKE %...%。

MYSQL 具有从字符串中替换/删除字符的功能,但找不到在带有通配符 LIKE 的查询中使用它们的方法。

任何帮助将不胜感激。

【问题讨论】:

  • 服务器端语言是什么? PHP ?
  • 它说 mysql 和 Henry 正在谈论查询 ;)

标签: mysql select wildcard sql-like


【解决方案1】:

我在零件编号和不需要的字符方面遇到了同样的问题。 我的解决方案是

SELECT * FROM parts WHERE replace(partnumber, '-', '') LIKE '$searchterm%';

【讨论】:

  • 这个答案与接受的答案有何不同?
【解决方案2】:

我看到了两种方法:

  1. 如果您只允许几个额外的字符,那么您可以准备一个从这些额外字符中去除的字符串,并且您通常会使用 LIKE 运算符

    select * from phoneTable where replace(replace(phone, '+', ''), '-', '') LIKE '%123%'
    

    当然,您需要与允许的额外字符数一样多的替换调用

  2. 您使用正则表达式,假设您正在搜索模式 123

    select * from phoneTable where phone REGEXP '.*1[^0-9]*2[^0-9]*3'
    

【讨论】:

  • 一旦将 '%..%' 添加到第一个选项,它们都可以正常工作。非常感谢您的帮助。
  • 你说得对,我忘记了通配符,也没有尝试运行查询。答案已更正。
  • 我猜第一个选项更快
猜你喜欢
  • 2015-02-17
  • 1970-01-01
  • 2014-08-20
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-01-06
  • 2013-11-25
  • 1970-01-01
相关资源
最近更新 更多