如何忽略 MYSQL SELECT LIKE %...% 上的字符

Posted

技术标签:

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

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

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

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

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

任何帮助将不胜感激。

【问题讨论】:

服务器端语言是什么? php ? 它说 mysql 和 Henry 正在谈论查询 ;) 【参考方案1】:

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

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

【讨论】:

这个答案与接受的答案有何不同?【参考方案2】:

我看到了两种方法:

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

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

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

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

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

【讨论】:

一旦将 '%..%' 添加到第一个选项,它们都可以正常工作。非常感谢您的帮助。 你说得对,我忘记了通配符,也没有尝试运行查询。答案已更正。 我猜第一个选项更快

以上是关于如何忽略 MYSQL SELECT LIKE %...% 上的字符的主要内容,如果未能解决你的问题,请参考以下文章

mysql 如何根据 like 、not like 排序

为啥 MySQL 在使用带有通配符的 LIKE 运算符时会忽略假名敏感?

MYSQL SELECT WHERE LIKE WITH AES_ENCRYPT

MYSQL如何进行sql like (sql查询结果)的查询

mysql like查询语句

select 中 like 变量 该怎么写?