Uploaded image for project: 'Solr'
  1. Solr
  2. SOLR-8802

Make remaining mutable Queries immutable

    XMLWordPrintableJSON

Details

    • Improvement
    • Status: Open
    • Minor
    • Resolution: Unresolved
    • None
    • None
    • None
    • None

    Description

      See LUCENE-6531
      Mutable queries are an issue for automatic filter caching since modifying a query after it has been put into the cache will corrupt the cache. We should make all queries immutable (up to the boost) to avoid this issue.

      Since they are part of the public API I would suggest splitting them in an immutable class and a builder like was done for most other Queries before releasing an official 6.x version

      I did a quick scan through all derived classes of Query and I compiled the following list (ignoring sources in test or contrib folders)
      Some of them are already marked as experimental (but should perhaps receive the "official" @lucene.experimental tag ?)
      For some it's possibly not an issue since they should never end up in a filter cache (like MoreLikeThisQuery ?), but then a comment specifying the exception to the rule should perhaps be added.

      • solr/core:
        • org.apache.solr.search.ExtendedQueryBase: Several derived classes, among which:
        • org.apache.solr.query.FilterQuery
        • org.apache.solr.query.SolrRangeQuery (marked as @lucene.experimental)
        • org.apache.solr.search.RankQuery (marked in comment as experimental, but not its derived classes)
        • org.apache.solr.search.WrappedQuery
        • org.apache.solr.search.join.GraphQuery (marked as @lucene.experimental)
        • org.apache.solr.search.SolrConstantScoreQuery (marked in comment as experimental, but not the derived FunctionRangeQuery)

      Attachments

        Issue Links

          Activity

            People

              Unassigned Unassigned
              lvl Luc Vanlerberghe
              Votes:
              0 Vote for this issue
              Watchers:
              4 Start watching this issue

              Dates

                Created:
                Updated: