Howto perform a 'contains' search rather than 'starts with' using Lucene.Net

前端 未结 2 1973
伪装坚强ぢ
伪装坚强ぢ 2020-12-14 11:13

We use Lucene.NET to implement a full text search on a clients website. The search itself works already but we now want to implement a modification.

Currently all te

相关标签:
2条回答
  • 2020-12-14 11:41

    @Simon Svensson probably gave the better answer (i.e. you don't need this), but if you do, you should use a Shingle Filter.

    Note that this will make your index massively larger, since instead of just storing "orchestra", you will store "orc", "rch", "che", "hes"... But just having a plain term query with leading wildcards will be massively slow. It will essentially have to look through every single term in your corpus.

    0 讨论(0)
  • 2020-12-14 11:51

    First off, I assume you're using StandardAnalyzer, or something similar. Your linked question fail to understand that you search for terms, and his case a* will match "Fleet Africa" because it's tokenized into "fleet" and "africa".

    You need to call QueryParser.SetAllowLeadingWildcard(true) to be able to write queries like field:*value*. Are you actually changing the string that's passed to QueryParser?

    You could parse the query as usual, and then implement a QueryVisitor that rewrites all TermQuery into WildcardQuery. That way you still support phrase searches.

    I see no good things in rewriting queries into prefix- or wildcard-queries. There is very little shared between an orc, or a chest, and an Orchestra, but both words will match. Instead, hook up your customer with an analyzer that supports stemming, synonyms, and provide a spell correction feature to fix simple searching mistakes.

    0 讨论(0)
提交回复
热议问题