अन्य यौगिक अनुक्रमणिका कुंजियों के बावजूद, आपको शामिल करना होगा $मेटा
सही छँटाई पाने के लिए "textScore" के लिए:
db.collection.find(
{ "$text": { "$search": "\"[email protected]\""}},
{ "score": { "$meta": "textScore" } }
).sort({
"score": { "$meta": "textScore" }, "Date": 1
})
तो स्वाभाविक रूप से आप चाहते हैं कि "स्कोर" पहले क्रमबद्ध हो, और फिर "तारीख" के अनुसार खोज की प्रासंगिकता के आधार पर चीजों को सही ढंग से रैंक किया जा सके।
अनुक्रमणिका का क्रम कोई मायने नहीं रखता, लेकिन निश्चित रूप से आपके पास "एक" टेक्स्ट इंडेक्स हो सकता है। इसलिए सुनिश्चित करें कि आप बनाने से पहले अन्य सभी को छोड़ दें:
db.collection.createIndex({
"From": "text",
"To": "text",
"CC":"text",
"BCC": "text",
"Date":1
})
ऐसे इंडेक्स देखें जो इसके साथ चालू हों:
db.collection.getIndicies()
या बस सब कुछ छोड़ दें और नई शुरुआत करें:
db.collection.dropIndexes()
हालाँकि आप जिस डेटा की खोज कर रहे हैं, उसके लिए मैंने सोचा होगा कि प्रत्येक क्षेत्र पर एक नियमित कंपाउंड इंडेक्स आपके लिए बेहतर होना चाहिए। "ईमेल" पतों की तलाश एक "सटीक मिलान" होनी चाहिए, और यदि आप प्रत्येक फ़ील्ड के लिए एक से अधिक आइटम की अपेक्षा करते हैं तो वे स्ट्रिंग्स की सरणियाँ होनी चाहिए, जैसे:
{
"TO": ["[email protected]"],
"FROM": ["[email protected]"],
"CC": ["[email protected]","[email protected]"],
"BCC": [],
"Date": ISODate("2015-07-27T13:42:05.535Z")
}
फिर आपको प्रत्येक फ़ील्ड पर अलग-अलग इंडेक्स की आवश्यकता होती है, संभवतः "दिनांक" के साथ कंपाउंड में:
db.email.createIndex({ "TO": 1, "Date": 1 })
db.email.createIndex({ "FROM": 1, "Date": 1 })
db.email.createIndex({ "CC": 1, "Date": 1 })
db.email.createIndex({ "BCC": 1, "Date": 1 })
और $or
के साथ क्वेरी करें
शर्त:
db.email.find({
"$or": [
{ "TO": "[email protected]" },
{ "FROM": "[email protected]" },
{ "CC": "[email protected]" },
{ "BCC": "[email protected]" }
],
"Date": { "$lt": new Date() }
})
अगर आप .explain(true)
(वर्बोज़) उस से आउटपुट, आपको यह देखना चाहिए कि विजेता योजना सभी निर्दिष्ट इंडेक्स का "इंडेक्स इंटरसेक्शन" है। यह बहुत कारगर साबित होता है क्योंकि प्रत्येक फ़ील्ड (और चयनित अनुक्रमणिका) का सटीक मिलान मान होता है, और अनुक्रमित तिथि पर एक श्रेणी मिलान होता है।
टेक्स्ट खोजों के "फजी मिलान" की तुलना में यह आपके लिए बहुत बेहतर होगा। यहां तक कि रेगुलर एक्सप्रेशन भी यहां सामान्य रूप से बेहतर काम करना चाहिए (ई-मेल पतों के लिए) और विशेष रूप से यदि वे "एंकर" हैं ^
स्ट्रिंग की शुरुआत में।
टेक्स्ट इंडेक्स "शब्द जैसे टोकन" से मेल खाने के लिए हैं, लेकिन यह आपका डेटा नहीं होना चाहिए। $या
अच्छा नहीं दिखता है, लेकिन इसे बहुत बेहतर काम करना चाहिए।