在 MySql 中使用搜索的正确结构是什么soundex()
?我知道如何生成 soundex():
select soundex('str');
只是不确定如何将其包含在我的查询中。
name
如果您要针对 table字段搜索“lewis” people
,请执行以下查询:
SELECT *
FROM people
WHERE soundex("lewis") = soundex(name);
显然,soundex 不是为这样的部分设计的(例如SELECT SOUNDEX('house cleaning'), SOUNDEX('house')
,它不匹配),但如果你想执行一个讨厌的SOUNDEX LIKE
,你可以
SELECT * FROM tablename WHERE SOUNDEX(column) LIKE CONCAT(SOUNDEX('partial_string'), '%')
你也可以做
SELECT * FROM tablename WHERE SOUNDEX(column) LIKE CONCAT(TRIM(TRAILING '0' FROM SOUNDEX('hows ')), '%')
这个“有点”有效
这应该工作
select * from table_name where soundex(column_name) = soundex('word');
这是阅读这些内容的好地方:http ://www.postgresonline.com/journal/archives/158-Where-is-soundex-and-other-warm-and-fuzzy-string-things.html
MySQL 现在有一种本地方式来执行此操作!
您可以使用该语法SOUNDS LIKE
进行相似性搜索。
SELECT * FROM table Where SOUNDEX(`field1`) = SOUNDEX(`field2`);
相当于:
SELECT * FROM table Where `field1` SOUNDS LIKE `field2`;