// PHP利用ICU扩展intl实现汉字转拼音
echo transliterator_transliterate('Any-Latin; Latin-ASCII; Lower()', '德克士'); //de ke shi
echo transliterator_transliterate('Any-Latin; Latin-ASCII; Lower()', '得克'); //de ke
// 假设name字段内容为"德克士",则name_fts字段内容为"de ke shi".
// MySQL全文检索字段name_fts中同时包含"得克"关键字de和ke的商店记录.
// 所以 name_fts 中包含de和ke的店铺都能显示出来.
SELECT name FROM store
WHERE MATCH(name_fts) AGAINST('+de +ke' IN BOOLEAN MODE)
ORDER BY id DESC LIMIT 5;
php 不是有sphinx和xunsearch嗎
試試elasticsearch搜尋引擎,支援分詞,全文搜索,還可以更依照相似度排序
這種要不是自己有個搜尋部門自己開發,就是用現在流行的一些開源搜尋引擎,像是solr和elasticsearch
我說下我的思路:漢字轉拼音後進行全文檢索.