Uploaded image for project: 'Lucene - Core'
  1. Lucene - Core
  2. LUCENE-4628

Add common terms query to gracefully handle very high frequent terms dynamically


    • Improvement
    • Status: Closed
    • Minor
    • Resolution: Fixed
    • None
    • 4.1, 6.0
    • modules/other
    • None
    • New, Patch Available


      I had this problem quite a couple of times the last couple of month that searches very often contained super high frequent terms and disjunction queries became way too slow. The main problem was that stopword filtering wasn't really an option since in the domain those high-freq terms where not really stopwords though. So for instance searching for a song title "this is it" or for a band "A" didn't really fly with stopwords. I thought about that for a while and came up with a query based solution that decides based on a threshold if something is considered a stopword or not and if so it moves the term in two boolean queries one for high-frequent and one for low-frequent such that those high frequent terms are only matched if the low-frequent sub-query produces a match. Yet if all terms are high frequent it makes the entire thing a Conjunction which gave me reasonable results as well as performance.


        1. LUCENE-4628.patch
          27 kB
          Simon Willnauer
        2. LUCENE-4628.patch
          24 kB
          Simon Willnauer



            simonw Simon Willnauer
            simonw Simon Willnauer
            0 Vote for this issue
            7 Start watching this issue