Опитахте ли текстовото търсене, за да видите дали не се държи правилно? Работи както се очаква за мен на MongoDB 2.6.7:
> db.test.drop()
> db.test.insert({ "t" : "I'm on time, not late or delayed" })
> db.test.insert({ "t" : "I'm either late or delayed" })
> db.test.insert({ "t" : "Time flies like a banana" })
> db.test.ensureIndex({ "t" : "text" })
> db.test.find({ "$text" : { "$search" : "time late delay" } }, { "_id" : 0 })
{ "t" : "I'm on time, not late or delayed" }
{ "t" : "Time flies like a banana" }
{ "t" : "I'm either late or delayed" }
> db.test.find({ "$text" : { "$search" : "late delay" } }, { "_id" : 0 })
{ "t" : "I'm on time, not late or delayed" }
{ "t" : "I'm either late or delayed" }
> db.test.find({ "$text" : { "$search" : "late delay \"on time\"" } }, { "_id" : 0 })
{ "t" : "I'm on time, not late or delayed" }
Защо "време" е в terms
масив в обяснението? Защото ако фразата "on time"
се среща в документ, терминът time
трябва също. MongoDB използва текстовия индекс до степента, в която може, за да помогне за намирането на фразата и след това ще провери резултатите от индекса, за да види кой всъщност съвпада с цялата фраза, а не само с термините във фразата.