MongoDB हमें वाइल्डकार्ड टेक्स्ट इंडेक्स बनाने की क्षमता प्रदान करता है।
वाइल्डकार्ड टेक्स्ट इंडेक्स वाइल्डकार्ड इंडेक्स के समान हैं, सिवाय इसके कि वाइल्डकार्ड टेक्स्ट इंडेक्स $text का समर्थन करते हैं ऑपरेटर, जबकि वाइल्डकार्ड इंडेक्स नहीं करते हैं।
उस ने कहा, प्रत्येक इंडेक्स प्रकार बनाना इस अर्थ में बहुत समान है कि वे दोनों वाइल्डकार्ड साझा करते हैं $** फ़ील्ड पैटर्न।
उदाहरण
मान लीजिए हमारे पास posts . नामक संग्रह है , और इसमें ऐसे दस्तावेज़ होते हैं जो इस तरह दिखते हैं:
{
"_id" : 1,
"title" : "Title text...",
"body" : "Body text...",
"abstract" : "Abstract text...",
"tags" : [
"tag1",
"tag2",
"tag3"
]
} हम उस संग्रह पर इस तरह एक वाइल्डकार्ड टेक्स्ट इंडेक्स बना सकते हैं:
db.posts.createIndex( { "$**": "text" } ) आउटपुट:
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
वह वाइल्डकार्ड $** . का उपयोग करता है सभी टेक्स्ट फ़ील्ड पर एक इंडेक्स बनाने के लिए फ़ील्ड पैटर्न। जब आप इस तरह की एक अनुक्रमणिका बनाते हैं, तो MongoDB संग्रह में प्रत्येक दस्तावेज़ के लिए स्ट्रिंग डेटा वाले प्रत्येक फ़ील्ड को अनुक्रमित करता है।
ऐसा करना उपयोगी हो सकता है यदि संग्रह में बहुत सारी असंरचित सामग्री है, और दस्तावेज़ों में टेक्स्ट फ़ील्ड की कोई संगति नहीं है। ऐसे मामलों में, आप इंडेक्स में फ़ील्ड को स्पष्ट रूप से शामिल नहीं कर पाएंगे क्योंकि आपको नहीं पता होगा कि दस्तावेज़ों में कौन से फ़ील्ड होने जा रहे हैं।
भारित फ़ील्ड
आप weights का उपयोग कर सकते हैं वाइल्डकार्ड टेक्स्ट इंडेक्स में फ़ील्ड को अलग-अलग वज़न असाइन करने के लिए पैरामीटर।
उदाहरण:
db.posts.createIndex(
{ "$**": "text" },
{ weights: {
body: 10,
abstract: 5
}
}
) आउटपुट:
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
इस मामले में, body फ़ील्ड को 10 . का भार मिलता है और abstract फ़ील्ड को 5 . का भार मिलता है . इसका मतलब है कि body फ़ील्ड में एब्सट्रैक्ट फ़ील्ड का प्रभाव दोगुना है, और अन्य सभी टेक्स्ट फ़ील्ड के प्रभाव का दस गुना है (क्योंकि उन्हें 1 का डिफ़ॉल्ट भार सौंपा जाएगा)।
उस इंडेक्स को बनाने के बाद, अगर हम getIndexes() . को कॉल करते हैं संग्रह के लिए सभी अनुक्रमणिका वापस करने के लिए, हम फ़ील्ड को दिए गए भार देख सकते हैं:
db.posts.getIndexes() परिणाम:
[
{
"v" : 2,
"key" : {
"_id" : 1
},
"name" : "_id_"
},
{
"v" : 2,
"key" : {
"_fts" : "text",
"_ftsx" : 1
},
"name" : "$**_text",
"weights" : {
"$**" : 1,
"abstract" : 5,
"body" : 10
},
"default_language" : "english",
"language_override" : "language",
"textIndexVersion" : 3
}
]
जैसी अपेक्षित थी, body फ़ील्ड को 10 मिलता है , abstract फ़ील्ड को 5 मिलता है , और अन्य सभी को 1 . मिलता है ।