MongoDB
 sql >> डेटाबेस >  >> NoSQL >> MongoDB

$text क्वेरी और $ या mongodb/mongoose में एकाधिक टेक्स्ट खोज कैसे करें?

वह वास्तविक त्रुटि बताती है कि आपका मोंगोडब 2.6 से कम का संस्करण है (इसलिए उस तरह से कोई पाठ खोज नहीं)। लेकिन आप वैसे भी दो कारणों से ऐसा नहीं कर सकते।

  1. एक $or एक्सप्रेशन में केवल एक . हो सकता है विशेष अनुक्रमणिका व्यंजक, तर्कों में या तो "पाठ" या "भू-स्थानिक" होना।

  2. आप "दो" विभिन्न क्षेत्रों पर पाठ खोजों की अपेक्षा कर रहे हैं और आपके पास केवल एक . हो सकता है प्रति संग्रह पाठ अनुक्रमणिका। हालाँकि उस एकल अनुक्रमणिका को दस्तावेज़ में कई क्षेत्रों में फैलाया जा सकता है। लेकिन आप अलग-अलग क्षेत्रों के लिए अलग-अलग खोज शब्द नहीं पूछ सकते।

दस्तावेज़ीकरण उद्धरण :

और यह भी कहना चाहिए "आप $or . का उपयोग नहीं कर सकते एक $text . के साथ अभिव्यक्ति या $near ऑपरेटर जहां या तो एक से अधिक स्थितियों में उपयोग किया जाता है।" लेकिन वह छोटी सी जानकारी गायब है, लेकिन फिर भी आप ऐसा नहीं कर सकते।

आपका सिंटैक्स आम तौर पर सही नहीं है, लेकिन MongoDB के समर्थित संस्करण में सही सिंटैक्स के साथ भी आपको $or का उपयोग करने का प्रयास करने में त्रुटि मिलेगी इस तरह:

Error: error: {
    "$err" : "Can't canonicalize query: BadValue Too many text expressions",
    "code" : 17287
}

तो इसे हल करने के लिए आपको चाहिए:

  1. $text . का समर्थन करने वाला 2.6 या इससे अधिक का MongoDB सर्वर संस्करण होना सिंटैक्स (या कमांड फॉर्म के साथ लाइव)

  2. एकाधिक क्षेत्रों में अनुक्रमण के साथ रहने और एकल अनुक्रमणिका का उपयोग करने के लिए।

  3. अपनी "या" शर्तों के स्थान पर "पृथक प्रश्नों" को निष्पादित करने के लिए और अपने क्लाइंट एपीआई इंटरफ़ेस में परिणामों को "गठबंधन" करने के लिए।

MongoDB टेक्स्ट सर्च के साथ इस तरह की "या" स्थितियां प्राप्त करने का यही एकमात्र तरीका है।



  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. PHP MongoDB $in/$or . का उपयोग करके कई दस्तावेज़ अपडेट करता है

  2. स्प्रिंग बूट 2.0.5.रिलीज और मोंगो 4.0 कनेक्शन मुद्दे

  3. ReactiveMongo:FindAndModify द्वारा लौटाए गए BSON को JSON में कैसे बदलें

  4. mongoDB संबंधित समस्या को कुशलतापूर्वक कैसे हल करें?

  5. MongoDB:क्वेरी निहित सीमा (256) है?