Korzystaj z funkcji wyszukiwania tekstu w Cloud Firestore, aby wyszukiwać określone ciągi znaków w kolekcji.
Zanim zaczniesz
Zanim zaczniesz korzystać z wyszukiwania tekstowego, wykonaj te czynności:
Upewnij się, że masz dostęp do istniejącej bazy danych operacji zgodnej z MongoDB lub utwórz bazę danych i połącz się z nią.
Sprawdź, czy masz indeks tekstowy, lub utwórz indeks tekstowy.
Uruchamianie wyszukiwania tekstowego
Wyszukiwanie tekstu wykorzystuje operator $text w filtrze.
Określ ciąg znaków, którego dotyczy zapytanie, w argumencie $search.
Przeprowadzanie ogólnego wyszukiwania tekstowego
Aby przeprowadzić ogólne wyszukiwanie tekstu, uruchom to polecenie:
# Find search
db.cities.find({ $text: { $search: "french bread" } })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "french bread" } } }
]);
Jeśli indeks jest podzielony na partycje, możesz filtrować według partycji, uwzględniając ją w filtrze równości „i” w wyszukiwaniu.
Jeśli na przykład masz partycję city, możesz filtrować wyszukiwanie tekstowe w ten sposób:
db.myCollection.find( { $and: [
{ $text: { $search: "french bread" } },
{ "city": "Paris" }
] } )
Możesz też filtrować agregację na podstawie partycji. Przykład:
db.myCollection.aggregate([
{ $match: { $text: { $search: "french bread" } } },
{ "city": "Paris" }
] );
Wartość partycji musi być ciągiem znaków. Filtr partycji musi być połączony z wyszukiwaniem tekstowym za pomocą operatora „and”.
Ustawianie języka wyszukiwania tekstowego
Język wyszukiwania tekstowego możesz ustawić za pomocą argumentu $language. Przykład:
db.cities.find({ $text: { $search: "french bread", $language: "en"} })
Jeśli nie ustawisz języka, wyszukiwanie będzie używać języka indeksu tekstowego.
Wyszukiwanie dokładnego terminu
Aby wyszukać dokładne słowo, skonfiguruj je jako ciąg słów ujęty w cudzysłów. Przykład:
# Find search
db.cities.find({ $text: { $search: "\"best french bread\"" } })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "\"best french bread\"" } } },
]);
Wyszukiwanie kombinacji haseł
Aby wyszukiwanie tekstu było bardziej precyzyjne, określ ciąg wyrazów. Na przykład to wyszukiwanie zwraca dokumenty pasujące do kombinacji najlepszy ORAZ francuski ORAZ („chleb” LUB „jest”):
# Find search
db.cities.find({ $text: { $search: "\"best\" \"french\" bread is" } })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "\"best\" \"french\" bread is" } } },
]);
Wykluczanie hasła
Aby wykluczyć termin z wyszukiwania tekstowego, dodaj przed nim myślnik (-):
# Find search
db.cities.find({ $text: { $search: "best bread -french"} })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "best bread -french" } } },
]);
Obliczanie wyniku trafności
Użyj wyrażenia {$meta: "textScore"}, aby obliczyć wynik trafności dokumentów pasujących do wyszukiwania tekstowego. Aby posortować wyniki w kolejności malejącej według wyniku, użyj w wyrażeniu sortowania symbolu $meta. Oto przykłady, w których SCORE_FIELD to nazwa pola używanego do przechowywania wartości wyniku:
# Find search
db.cities
.find({ $text: { $search: "best french bread" } })
.sort({ SCORE_FIELD: { $meta: "textScore" } })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "best french bread" } } },
{ $sort: { "SCORE_FIELD": { $meta: "textScore"} } },
]);
W wyrażeniach projekcji możesz też używać wyniku tekstowego. Przykład:
# Find search
db.cities
.find({ $text: { $search: "best french bread" } })
.project({ score: { $meta: "textScore" } })
# Aggregation search
db.cities.aggregate([
{ $match: { $text: { $search: "best french bread" } } },
{ $project: { "scoreField": { $meta: "textScore"} } },
]);
Rozwiń wyszukiwanie
Aby zwiększyć trafność wyników wyszukiwania tekstowego, operator $text rozszerza ciąg wyszukiwania zgodnie z określonym językiem, aby uwzględniać dopasowania do synonimów uwzględniających kontekst, form podstawowych, terminów z poprawioną pisownią, odmian diakrytycznych i innych.
Ograniczenia
- Operatorów
$neari$textnie można używać w tym samym wyszukiwaniu tekstowym. - W przypadku wyszukiwania
findlubaggregationdozwolony jest tylko 1 operator$text. - W agregacjach etap
$matchz$textmusi być pierwszym etapem potoku. - Element
$textmoże być zagnieżdżony tylko w elementach$andi$or. - Jeśli
$textznajduje się w$or, rozłączne warunki wyszukiwania mogą używać istniejących indeksów uporządkowanych do optymalizacji wyszukiwania. Jeśli pozostałe składniki alternatywy nie są indeksowane, wyszukiwanie opiera się na skanowaniu kolekcji. $textnie można używać ze wskazówkami.- W przypadku zapytań z wyszukiwaniem tekstowym nie można sortować wyników według
$natural.