एलिटिक्स खोज - क्वेरी डीएसएल

इलास्टिक्स खोज में, JSON के आधार पर क्वेरी का उपयोग करके खोज की जाती है। एक क्वेरी दो खंडों से बनी है -

  • Leaf Query Clauses - ये खंड मैच, टर्म या रेंज हैं, जो विशिष्ट क्षेत्र में एक विशिष्ट मूल्य की तलाश करते हैं।

  • Compound Query Clauses - ये क्वेरीज़ वांछित जानकारी निकालने के लिए लीफ क्वेरी क्लॉज़ और अन्य यौगिक क्वेरीज़ का संयोजन हैं।

इलास्टिसर्च बड़ी संख्या में प्रश्नों का समर्थन करता है। एक क्वेरी एक क्वेरी कुंजी शब्द से शुरू होती है और फिर JSON ऑब्जेक्ट के रूप में अंदर स्थितियां और फ़िल्टर होते हैं। नीचे विभिन्न प्रकार के प्रश्नों का वर्णन किया गया है।

मैच सभी क्वेरी

यह सबसे बुनियादी क्वेरी है; यह सभी सामग्री और 1.0 के स्कोर के साथ हर वस्तु के लिए देता है।

POST /schools/_search
{
   "query":{
      "match_all":{}
   }
}

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "took" : 7,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 2,
         "relation" : "eq"
      },
      "max_score" : 1.0,
      "hits" : [
         {
            "_index" : "schools",
            "_type" : "school",
            "_id" : "5",
            "_score" : 1.0,
            "_source" : {
               "name" : "Central School",
               "description" : "CBSE Affiliation",
               "street" : "Nagan",
               "city" : "paprola",
               "state" : "HP",
               "zip" : "176115",
               "location" : [
                  31.8955385,
                  76.8380405
               ],
               "fees" : 2200,
               "tags" : [
                  "Senior Secondary",
                  "beautiful campus"
               ],
               "rating" : "3.3"
            }
         },
         {
            "_index" : "schools",
            "_type" : "school",
            "_id" : "4",
            "_score" : 1.0,
            "_source" : {
               "name" : "City Best School",
               "description" : "ICSE",
               "street" : "West End",
               "city" : "Meerut",
               "state" : "UP",
               "zip" : "250002",
               "location" : [
                  28.9926174,
                  77.692485
               ],
               "fees" : 3500,
               "tags" : [
                  "fully computerized"
               ],
               "rating" : "4.5"
            }
         }
      ]
   }
}

पूर्ण पाठ प्रश्न

इन प्रश्नों का उपयोग पाठ के पूर्ण निकाय जैसे अध्याय या समाचार लेख को खोजने के लिए किया जाता है। यह क्वेरी उस विशेष सूचकांक या दस्तावेज़ से जुड़े विश्लेषक के अनुसार काम करती है। इस भाग में, हम विभिन्न प्रकार के पूर्ण पाठ प्रश्नों पर चर्चा करेंगे।

मैच की क्वेरी

यह क्वेरी एक या अधिक फ़ील्ड के मानों के साथ एक पाठ या वाक्यांश से मेल खाती है।

POST /schools*/_search
{
   "query":{
      "match" : {
         "rating":"4.5"
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 44,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 1,
         "relation" : "eq"
      },
      "max_score" : 0.47000363,
      "hits" : [
         {
            "_index" : "schools",
            "_type" : "school",
            "_id" : "4",
            "_score" : 0.47000363,
            "_source" : {
               "name" : "City Best School",
               "description" : "ICSE",
               "street" : "West End",
               "city" : "Meerut",
               "state" : "UP",
               "zip" : "250002",
               "location" : [
                  28.9926174,
                  77.692485
               ],
               "fees" : 3500,
               "tags" : [
                  "fully computerized"
               ],
               "rating" : "4.5"
            }
         }
      ]
   }
}

मल्टी मैच क्वेरी

यह क्वेरी एक से अधिक फ़ील्ड के साथ टेक्स्ट या वाक्यांश से मेल खाती है।

POST /schools*/_search
{
   "query":{
      "multi_match" : {
         "query": "paprola",
         "fields": [ "city", "state" ]
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 12,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 1,
         "relation" : "eq"
      },
      "max_score" : 0.9808292,
      "hits" : [
         {
            "_index" : "schools",
            "_type" : "school",
            "_id" : "5",
            "_score" : 0.9808292,
            "_source" : {
               "name" : "Central School",
               "description" : "CBSE Affiliation",
               "street" : "Nagan",
               "city" : "paprola",
               "state" : "HP",
               "zip" : "176115",
               "location" : [
                  31.8955385,
                  76.8380405
               ],
               "fees" : 2200,
               "tags" : [
                  "Senior Secondary",
                  "beautiful campus"
               ],
               "rating" : "3.3"
            }
         }
      ]
   }
}

क्वेरी स्ट्रिंग क्वेरी

यह क्वेरी क्वेरी पार्सर और क्वेरी_स्ट्रिंग कीवर्ड का उपयोग करती है।

POST /schools*/_search
{
   "query":{
      "query_string":{
         "query":"beautiful"
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 60,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
      "value" : 1,
      "relation" : "eq"
   },
………………………………….

शब्द स्तर प्रश्न

ये प्रश्न मुख्य रूप से संरचित डेटा जैसे नंबर, दिनांक और एनम से निपटते हैं।

POST /schools*/_search
{
   "query":{
      "term":{"zip":"176115"}
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

……………………………..
hits" : [
   {
      "_index" : "schools",
      "_type" : "school",
      "_id" : "5",
      "_score" : 0.9808292,
      "_source" : {
         "name" : "Central School",
         "description" : "CBSE Affiliation",
         "street" : "Nagan",
         "city" : "paprola",
         "state" : "HP",
         "zip" : "176115",
         "location" : [
            31.8955385,
            76.8380405
         ],
      }
   }
]   
…………………………………………..

रेंज क्वेरी

इस क्वेरी का उपयोग दिए गए मानों की श्रेणियों के बीच मान रखने वाली वस्तुओं को खोजने के लिए किया जाता है। इसके लिए, हमें ऑपरेटरों का उपयोग करने की आवश्यकता है जैसे -

  • gte - से अधिक के बराबर
  • gt - अधिक से अधिक
  • lte - के बराबर-से-कम
  • lt - कम-से-कम

उदाहरण के लिए, नीचे दिए गए कोड को देखें -

POST /schools*/_search
{
   "query":{
      "range":{
         "rating":{
            "gte":3.5
         }
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 24,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 1,
         "relation" : "eq"
      },
      "max_score" : 1.0,
      "hits" : [
         {
            "_index" : "schools",
            "_type" : "school",
            "_id" : "4",
            "_score" : 1.0,
            "_source" : {
               "name" : "City Best School",
               "description" : "ICSE",
               "street" : "West End",
               "city" : "Meerut",
               "state" : "UP",
               "zip" : "250002",
               "location" : [
                  28.9926174,
                  77.692485
               ],
               "fees" : 3500,
               "tags" : [
                  "fully computerized"
               ],
               "rating" : "4.5"
            }
         }
      ]
   }
}

शब्द स्तर के अन्य प्रकार के प्रश्न भी मौजूद हैं जैसे -

  • Exists query - यदि एक निश्चित क्षेत्र में अशक्त मान है।

  • Missing query - यह क्वेरी मौजूद करने के लिए पूरी तरह से विपरीत है, यह क्वेरी विशिष्ट फ़ील्ड या शून्य मान वाले फ़ील्ड के बिना ऑब्जेक्ट खोजती है।

  • Wildcard or regexp query - यह क्वेरी वस्तुओं में पैटर्न खोजने के लिए नियमित अभिव्यक्ति का उपयोग करती है।

यौगिक प्रश्न

ये प्रश्न बूलियन ऑपरेटरों जैसे कि और, या, अलग-अलग सूचकांकों के लिए या फ़ंक्शन कॉल आदि का उपयोग करके एक दूसरे के साथ विलय किए गए विभिन्न प्रश्नों का एक संग्रह है।

POST /schools/_search
{
   "query": {
      "bool" : {
         "must" : {
            "term" : { "state" : "UP" }
         },
         "filter": {
            "term" : { "fees" : "2200" }
         },
         "minimum_should_match" : 1,
         "boost" : 1.0
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 6,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 0,
         "relation" : "eq"
      },
      "max_score" : null,
      "hits" : [ ]
   }
}

जियो क्वेरी

ये क्वेरी जियो लोकेशन और जियो पॉइंट से निपटती है। ये प्रश्न किसी भी स्थान के पास के स्कूलों या किसी अन्य भौगोलिक वस्तु का पता लगाने में मदद करते हैं। आपको जियो पॉइंट डेटा टाइप का उपयोग करना होगा।

PUT /geo_example
{
   "mappings": {
      "properties": {
         "location": {
            "type": "geo_shape"
         }
      }
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{  "acknowledged" : true,
   "shards_acknowledged" : true,
   "index" : "geo_example"
}

अब हम ऊपर बनाए गए इंडेक्स में डेटा पोस्ट करते हैं।

POST /geo_example/_doc?refresh
{
   "name": "Chapter One, London, UK",
   "location": {
      "type": "point",
      "coordinates": [11.660544, 57.800286]
   }
}

उपरोक्त कोड चलाने पर, हमें नीचे दिखाए अनुसार प्रतिक्रिया मिलती है -

{
   "took" : 1,
   "timed_out" : false,
   "_shards" : {
      "total" : 1,
      "successful" : 1,
      "skipped" : 0,
      "failed" : 0
   },
   "hits" : {
      "total" : {
         "value" : 2,
         "relation" : "eq"
      },
      "max_score" : 1.0,
      "hits" : [
         "_index" : "geo_example",
         "_type" : "_doc",
         "_id" : "hASWZ2oBbkdGzVfiXHKD",
         "_score" : 1.0,
         "_source" : {
            "name" : "Chapter One, London, UK",
            "location" : {
               "type" : "point",
               "coordinates" : [
                  11.660544,
                  57.800286
               ]
            }
         }
      }
   }