मेरे लिए यह हल करने का अंतिम विकल्प स्टैक ओवरव्लो से पूछना था।अपाचे सोलर क्वेरी में कैसे करें या शून्य मान?
मैं दस्तावेजों अपने क्षेत्रों में से एक या उस पर एक विशिष्ट मूल्य है कि एक मूल्य नहीं है पाने के लिए एक Solr क्वेरी बनाने के लिए कोशिश कर रहा हूँ ...
theorically, इस क्वेरी काम किया जाना चाहिए था। > परिणाम गिनती: 15,383 // जॉन्स
क्वेरी: (नाम: {* के लिए *}) -
क्वेरी:: (जॉन नाम)
यहाँ कुछ जानकारी है - -> परिणाम गिनती: 61,013 // लोगों को एक नाम
क्वेरी है: - (नाम: {* के लिए *}) -> परिणाम गिनती: 216,888 // लोग है कि एक नाम
की जरूरत नहीं हैअब, जब मैं या ऑपरेटर के साथ एक ही क्वेरी में पहली और तीसरी क्वेरी का उपयोग करता हूं, तो मुझे उम्मीद है कि (216888 + 15383) परिणाम प्राप्त होंगे। लेकिन SOLR देता 15,383 परिणामों के लिए, बस तीसरे क्वेरी के प्रभाव पर ध्यान नहीं देता:
क्वेरी: + ((नाम: जॉन) (- (नाम: {* के लिए *}))) // यह है क्वेरी मैं था उपयोग किया गया।
क्या यह सोलर का एक बग है या क्या मैं क्वेरी में गलत कर रहा हूं? दो क्वेरी परिणामों को विलय करना एक अतिरिक्त समाधान है, लेकिन अगर मैं इसे सरल प्रश्न के साथ कर सकता हूं तो मैं अतिरिक्त कोड कार्यान्वयन नहीं करना चाहता हूं।
किसी भी मदद की सराहना की जाएगी।
q=(name:john OR -(name:[* TO *]))
मेरे लिए काम किया !! – Raj
यह वही है जो मुझे चाहिए था। धन्यवाद। क्या आप इस उदाहरण में 'AND *: * 'क्या करते हैं, इसकी व्याख्या करने में सक्षम होंगे? मैं देखता हूं कि अगर मैं उस भाग को छोड़ देता हूं तो मेरी खोज काम नहीं करती है, मुझे यकीन नहीं है कि क्यों। –
'*: *' सभी पंक्तियों का मतलब है। '*: * -name: *' का अर्थ किसी भी नाम के बिना सभी पंक्तियों का है। 'नाम: जॉन या (*: * -name: *) 'एसक्यूएल में' name = 'जॉन' या नाम IS NULL 'के रूप में अनुवादित किया जा सकता है – Semra