Data Connect की मदद से, पूरे टेक्स्ट में खोज करना

Firebase Data Connect में फ़ुल-टेक्स्ट सर्च की सुविधा उपलब्ध है. यह PostgreSQL की मदद से काम करती है. फ़ुल-टेक्स्ट सर्च की मदद से, बड़े डेटासेट में मौजूद जानकारी को तुरंत और आसानी से ढूंढा जा सकता है. इसके लिए, एक साथ कई कॉलम में कीवर्ड और वाक्यांशों को खोजा जाता है.

अपनी सेवा में फ़ुल-टेक्स्ट सर्च की सुविधा जोड़ी जा सकती है. सबसे पहले, अपने स्कीमा में मौजूद उस String में @searchable डायरेक्टिव जोड़ें जिसे आपको खोजना है. उदाहरण के लिए:

type Movie
  @table {

  # The fields you want to search over
  title: String! @searchable
  genre: String @searchable
  description: String @searchable
  tags: [String]

  # Some other fields that we won't search over
  rating: Float
  imageUrl: String!
  releaseYear: Int
}

इस डायरेक्टिव को जोड़ने के बाद, क्वेरी में <pluralType>_search फ़ील्ड जोड़कर, फ़ुल-टेक्स्ट खोज की जा सकती है. इस मामले में, यह movies_search होगा:

query SearchMovies($query: String) @auth(level: PUBLIC) {
  movies_search(query: $query) {
    id
    title
    imageUrl
    releaseYear
    genre
    rating
    tags
    description
  }
}

पूरे टेक्स्ट की खोज के नतीजों को फ़ाइन-ट्यून करना

@searchable डायरेक्टिव और _search फ़ील्ड में आर्ग्युमेंट जोड़कर, पूरे टेक्स्ट में खोज के नतीजों को बेहतर बनाया जा सकता है;

शेयर किए गए आर्ग्युमेंट

खोज के नतीजों को कंट्रोल करने के लिए, बुनियादी सूची वाले फ़ील्ड <pluralType> में इस्तेमाल किए गए कई तर्क इस्तेमाल किए जा सकते हैं:

  • order की मदद से, नतीजों का क्रम बदला जा सकता है. अगर इसे शामिल नहीं किया जाता है, तो नतीजे, काम के होने के हिसाब से घटते क्रम में दिखाए जाएंगे.
  • where की मदद से, खोज के लिए अतिरिक्त फ़िल्टर जोड़े जा सकते हैं. उदाहरण के लिए, सिर्फ़ किसी खास शैली की फ़िल्में खोजें.
  • limit का इस्तेमाल करने पर, क्वेरी के जवाब में सिर्फ़ टॉप X नतीजे दिखते हैं.
  • offset क्वेरी में, शुरुआती X नतीजों को स्किप कर दिया जाता है.
  • distinct जनरेट किए गए SQL में DISTINCT ऑपरेटर जोड़ता है.

भाषा चुनने का विकल्प

डिफ़ॉल्ट रूप से, पूरे टेक्स्ट की खोज करने की सुविधा, दस्तावेज़ों को अंग्रेज़ी में पार्स करती है. @searchable डायरेक्टिव पर भाषा के आर्ग्युमेंट का इस्तेमाल करके, इसे बदला जा सकता है:

type Movie
  @table {
  title: String! @searchable(language: "french")
  ...
}

सही भाषा चुनने से, PostgreSQL सटीक लेक्सिकल स्टेमिंग कर पाएगा. इससे यह पक्का करने में मदद मिलेगी कि आपकी खोज में काम के नतीजे न छूटें. अगर आपको एक से ज़्यादा कॉलम में खोजना है, तो उन सभी को एक ही भाषा में सेट करना होगा.

भाषाएं
  • सरल
  • ऐरेबिक
  • armenian
  • basque
  • catalan
  • danish
  • डच
  • इंग्लिश
  • फ़िनिश
  • फ़्रेंच
  • जर्मन
  • ग्रीक
  • hindi
  • हंगेरियन
  • indonesian
  • irish
  • italian
  • लिथुआनियन
  • nepali
  • नॉर्वेजियन

psql का इस्तेमाल करके, यहां दी गई क्वेरी से पूरी सूची पाई जा सकती है.

SELECT cfgname FROM pg_ts_config;

क्वेरी का फ़ॉर्मैट

डिफ़ॉल्ट रूप से, फ़ुल-टेक्स्ट सर्च की सुविधा, क्वेरी के लिए वेब सिमैंटिक्स का इस्तेमाल करती है. यह Google Search की तरह ही काम करती है. <pluralType>_search फ़ील्ड पर queryFormat आर्ग्युमेंट का इस्तेमाल करके, इस व्यवहार को बदला जा सकता है.

query SearchMovies($query: String) @auth(level: PUBLIC) {
  movies_search(query: $query, queryFormat: PHRASE) {
    ...
  }
}

क्वेरी फ़ॉर्मैट के लिए चार विकल्प उपलब्ध हैं:

  • QUERY, वेब सर्च इंजन को जाने-पहचाने सिमैंटिक देता है. जैसे, कोट की गई स्ट्रिंग, AND, और OR. यह डिफ़ॉल्ट रूप से चालू होता है.
  • PLAIN में, सभी शब्दों का मिलान किया जाता है. हालांकि, यह ज़रूरी नहीं है कि वे एक साथ हों ("brown dog" का मिलान "the brown and white dog" या "the white and brown dog" से किया जाएगा).
  • वाक्यांश, किसी वाक्यांश से पूरी तरह मेल खाता है. जैसे, "भूरा कुत्ता" से "सफ़ेद और भूरा कुत्ता" मेल खाएगा, लेकिन "भूरा और सफ़ेद कुत्ता" मेल नहीं खाएगा.
  • ADVANCED की मदद से, tsquery ऑपरेटर के पूरे सेट का इस्तेमाल करके, मुश्किल क्वेरी बनाई जा सकती हैं.

कितने काम का है, इसका थ्रेशोल्ड

'कितने काम के हैं' थ्रेशोल्ड सेट करने का मतलब है कि आपकी खोज के नतीजे सिर्फ़ एक तय थ्रेशोल्ड से ऊपर की वैल्यू वाले होंगे. ज़्यादातर मामलों में, आपको इसे सेट करने की ज़रूरत नहीं होगी. ऐसा कोई भी नतीजा जो 0 से ज़्यादा काम का हो वह काम का नतीजा होगा.

हालांकि, अगर आपको लगता है कि खोज के नतीजे आपके काम के नहीं हैं, तो काम के नतीजों के थ्रेशोल्ड का इस्तेमाल करके उन्हें फ़िल्टर किया जा सकता है.

मिलते-जुलते होने के थ्रेशोल्ड के लिए सही वैल्यू का पता लगाने के लिए, आपको कुछ टेस्ट खोजें करनी चाहिए और _metadata.relevance को देखना चाहिए:

query SearchMovies($query: String) @auth(level: PUBLIC) {
  movies_search(query: $query) {
    id
    title
    _metadata {
      relevance
    }
    ...
  }
}

ऐसा थ्रेशोल्ड चुनें जिससे आपको लगता है कि काम के नतीजे नहीं मिल रहे हैं. इसके लिए:

query SearchMovies($query: String) @auth(level: PUBLIC) {
  movies_search(query: $query, relevanceThreshold: 0.05) {
    id
    title
    ...
  }
}

फ़ुल-टेक्स्ट सर्च, वेक्टर सिमिलैरिटी सर्च, और स्ट्रिंग पैटर्न फ़िल्टर में से किसी एक को चुनना

Data Connect आपको अपने डेटाबेस में खोजने के कुछ अलग-अलग तरीके उपलब्ध कराता है.

इस टेबल का इस्तेमाल करके, अपने इस्तेमाल के उदाहरण के लिए सही विकल्प चुनें.

पूरे टेक्स्ट की खोज वेक्टर के आधार पर मिलती-जुलती जानकारी खोजना स्ट्रिंग पैटर्न फ़िल्टर
सामान्य खोज की सुविधा लागू करने के लिए बेहतर यह सिमैंटिक तौर पर मिलती-जुलती लाइनों को ढूंढने के लिए अच्छा है. उदाहरण के लिए, सुझाव या 'इस तरह के और') टेक्स्ट से पूरी तरह मेल खाने वाले या रेगुलर एक्सप्रेशन की मदद से की गई खोजों के लिए बेहतर
लेक्सिकल स्टेमिंग करता है. इससे एक ही शब्द के अलग-अलग फ़ॉर्म या टेंस को मैच करने में मदद मिलती है इसके लिए Vertex AI की ज़रूरत होती है यह सबसे कम मेमोरी और डिस्क स्पेस का इस्तेमाल करता है, क्योंकि इसके लिए किसी इंडेक्स या जनरेट किए गए कॉलम की ज़रूरत नहीं होती
टेबल के एक से ज़्यादा कॉलम पर लागू किया जा सकता है एक बार में सिर्फ़ एक कॉलम के लिए काम करता है OR फ़िल्टर का इस्तेमाल करके, टेबल के एक से ज़्यादा कॉलम पर लागू किया जा सकता है
बड़े दस्तावेज़ों पर बेहतर परफ़ॉर्मेंस बड़े दस्तावेज़ों पर बेहतर परफ़ॉर्मेंस बड़े दस्तावेज़ों में खोज करने पर, यह कम असरदार होता है
यह जनरेट किए गए कॉलम और हर खोज के लिए इंडेक्स को सेव करने के लिए, मेमोरी और स्टोरेज ओवरहेड जोड़ता है