如何忽略 MYSQL SELECT LIKE %...% 上的字符
Posted
技术标签:
【中文标题】如何忽略 MYSQL SELECT LIKE %...% 上的字符【英文标题】:How to ignore characters on a MYSQL SELECT LIKE %...% 【发布时间】:2012-04-08 15:52:06 【问题描述】:我有一个带有phone
列的表格,其中数据可能在数字之间有空格、点、破折号或+ 号。
我需要使用忽略所有这些字符的 LIKE 通配符进行搜索,例如:
不幸的是,我无法清理原始表以删除非数字字符并执行普通的 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 运算符时会忽略假名敏感?
MYSQL SELECT WHERE LIKE WITH AES_ENCRYPT