एलिटिक्स खोज - क्वेरी डीएसएल
इलास्टिक्स खोज में, 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
]
}
}
}
}