Mongo如何在多個字段中查詢某個關鍵字?


If a text index has multiple fields in Mongo, how can I do a search in only one field since the weight is applied to the index and not to the query?

 

1 Answer

 

I assume you are using MongoDB version 2.4 to 3.x

You have no other choices than using MongoDB Text search.

below two approaches may helpful.

1. Indexing Multiple Fields (Compound Indexing)

db.yourcollection.createIndex({"textfield1":"text","textfield2":"text"})

Compound index is combination of both indices, works only if we search on both fields with given values.

2. Indexing the Entire Document (Wildcard Indexing)

db.yourcollection.createIndex({"$**":"text"})

Though the option two is not recommended. But if you use more text fields those are searchable every time, saves you time. One index fits for all.

reference: Full-Text Search in MongoDB (Just to take examples from it)

 

建立完索引后, 可以用如下的查詢:

db.collectionName.find({$text: {$search: "keyword"}})

 

但是好像只能查到帶有整個單詞的記錄,不能查到包含這個單詞的記錄。

 

詳細的查詢語法在這里: https://docs.mongodb.com/manual/reference/operator/query/text/

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM