mirror of
https://github.com/meilisearch/meilisearch.git
synced 2025-01-18 08:48:32 +08:00
limit the search in the FST
This commit is contained in:
parent
13ca30c4d8
commit
a262c67ec3
@ -326,20 +326,19 @@ pub fn traverse_query_tree<'o, 'txn>(
|
|||||||
{
|
{
|
||||||
let before = Instant::now();
|
let before = Instant::now();
|
||||||
|
|
||||||
// let byte = query.as_bytes()[0];
|
|
||||||
// let mut stream = if byte == u8::max_value() {
|
|
||||||
// words.search(&dfa).ge(&[byte]).into_stream()
|
|
||||||
// } else {
|
|
||||||
// words.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream()
|
|
||||||
// };
|
|
||||||
|
|
||||||
let Query { id, prefix, kind } = query;
|
let Query { id, prefix, kind } = query;
|
||||||
let docids = match kind {
|
let docids = match kind {
|
||||||
QueryKind::Tolerant(word) => {
|
QueryKind::Tolerant(word) => {
|
||||||
let dfa = if *prefix { build_prefix_dfa(word) } else { build_dfa(word) };
|
let dfa = if *prefix { build_prefix_dfa(word) } else { build_dfa(word) };
|
||||||
|
|
||||||
|
let byte = word.as_bytes()[0];
|
||||||
|
let mut stream = if byte == u8::max_value() {
|
||||||
|
words_set.search(&dfa).ge(&[byte]).into_stream()
|
||||||
|
} else {
|
||||||
|
words_set.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream()
|
||||||
|
};
|
||||||
|
|
||||||
let mut docids = Vec::new();
|
let mut docids = Vec::new();
|
||||||
let mut stream = words_set.search(&dfa).into_stream();
|
|
||||||
while let Some(input) = stream.next() {
|
while let Some(input) = stream.next() {
|
||||||
if let Some(matches) = pls.postings_list(reader, input)? {
|
if let Some(matches) = pls.postings_list(reader, input)? {
|
||||||
docids.extend(matches.iter().map(|d| d.document_id))
|
docids.extend(matches.iter().map(|d| d.document_id))
|
||||||
@ -352,8 +351,14 @@ pub fn traverse_query_tree<'o, 'txn>(
|
|||||||
// TODO support prefix and non-prefix exact DFA
|
// TODO support prefix and non-prefix exact DFA
|
||||||
let dfa = build_exact_dfa(word);
|
let dfa = build_exact_dfa(word);
|
||||||
|
|
||||||
|
let byte = word.as_bytes()[0];
|
||||||
|
let mut stream = if byte == u8::max_value() {
|
||||||
|
words_set.search(&dfa).ge(&[byte]).into_stream()
|
||||||
|
} else {
|
||||||
|
words_set.search(&dfa).ge(&[byte]).lt(&[byte + 1]).into_stream()
|
||||||
|
};
|
||||||
|
|
||||||
let mut docids = Vec::new();
|
let mut docids = Vec::new();
|
||||||
let mut stream = words_set.search(&dfa).into_stream();
|
|
||||||
while let Some(input) = stream.next() {
|
while let Some(input) = stream.next() {
|
||||||
if let Some(matches) = pls.postings_list(reader, input)? {
|
if let Some(matches) = pls.postings_list(reader, input)? {
|
||||||
docids.extend(matches.iter().map(|d| d.document_id))
|
docids.extend(matches.iter().map(|d| d.document_id))
|
||||||
|
Loading…
Reference in New Issue
Block a user