文章详情页
mysql - sphinx查询 "中国" 时也能查询到 "中华人民共和国"
浏览:99日期:2022-06-21 17:10:01
问题描述
sphinx初学者,有个疑问,之前没学sphinx的时候以为:查询 '中国' 时也能查询到 '中华人民共和国'查询 '大姨妈' 时也能查询到 '例假'查询 '苹果' 时也能查询到 'iPhone'类似这样的还有很多,网上没有找到相关的文章,不知该搜索什么关键词,所以在这里请教诸位,谢谢咯~~~如果支持,希望提供思路或操作步骤
问题解答
回答1:据我了解是不行的,因为sphinx是检索引擎+coreseek是中文分词功能,应该不具备这样的功能。
在sphinx.conf配置文件里也没看到相关,所以如果想要你所说的功能,应该是用其他的插件。
如果是纯粹提供一个思路的话:我们搜索出来的结果都不是直接展示出来的,而是要通过一个权重判断(增加权重字段),例如与中国相关的这些词中,权重最高的是中华人民共和国。其他词语也是一样,这样子应该能完成你想要得效果,纯粹mysql实现还比较容易,但在sphinx中比较难,因为它检索的逻辑都定死的。
回答2:想多了。sphinx只是根据关键词检索。近义词和相关词都是手动设计和智能机器学习来的。
回答3:这个叫搜索重写,最简单的方式是做一个别名表,先分词 -> 取别名 -> 归一化 -> 交给sphinx 查询。
相关文章:
1. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE语法实现存在即更新应该使用哪个标签?2. mysql - 表名称前缀到底有啥用?3. Navicat for mysql 中以json格式储存的数据存在大量反斜杠,如何去除?4. mysql - 数据库表中,两个表互为外键参考如何解决5. 哭辽 求大佬解答 控制器的join方法怎么转模型方法6. mysql储存json错误7. mysql - 怎么生成这个sql表?8. 怎么php怎么通过数组显示sql查询结果呢,查询结果有多条,如图。9. sql语句 - 如何在mysql中批量添加用户?10. 编辑成功不显示弹窗
排行榜
