文章詳情頁
mysql - sphinx查詢 "中國" 時也能查詢到 "中華人民共和國"
瀏覽:100日期:2022-06-21 17:10:01
問題描述
sphinx初學者,有個疑問,之前沒學sphinx的時候以為:查詢 '中國' 時也能查詢到 '中華人民共和國'查詢 '大姨媽' 時也能查詢到 '例假'查詢 '蘋果' 時也能查詢到 'iPhone'類似這樣的還有很多,網上沒有找到相關的文章,不知該搜索什么關鍵詞,所以在這里請教諸位,謝謝咯~~~如果支持,希望提供思路或操作步驟
問題解答
回答1:據我了解是不行的,因為sphinx是檢索引擎+coreseek是中文分詞功能,應該不具備這樣的功能。
在sphinx.conf配置文件里也沒看到相關,所以如果想要你所說的功能,應該是用其他的插件。
如果是純粹提供一個思路的話:我們搜索出來的結果都不是直接展示出來的,而是要通過一個權重判斷(增加權重字段),例如與中國相關的這些詞中,權重最高的是中華人民共和國。其他詞語也是一樣,這樣子應該能完成你想要得效果,純粹mysql實現還比較容易,但在sphinx中比較難,因為它檢索的邏輯都定死的。
回答2:想多了。sphinx只是根據關鍵詞檢索。近義詞和相關詞都是手動設計和智能機器學習來的。
回答3:這個叫搜索重寫,最簡單的方式是做一個別名表,先分詞 -> 取別名 -> 歸一化 -> 交給sphinx 查詢。
相關文章:
1. mysql - 怎么生成這個sql表?2. 哭遼 求大佬解答 控制器的join方法怎么轉模型方法3. Navicat for mysql 中以json格式儲存的數據存在大量反斜杠,如何去除?4. sql語句 - 如何在mysql中批量添加用戶?5. mysql儲存json錯誤6. mysql - 數據庫表中,兩個表互為外鍵參考如何解決7. mysql - 表名稱前綴到底有啥用?8. 編輯成功不顯示彈窗9. 怎么php怎么通過數組顯示sql查詢結果呢,查詢結果有多條,如圖。10. 在mybatis使用mysql的ON DUPLICATE KEY UPDATE語法實現存在即更新應該使用哪個標簽?
排行榜
