Uploaded image for project: 'Core Server'
  1. Core Server
  2. SERVER-97129

Migrate evaluate() for accumulator-based expressions

    • Type: Icon: Task Task
    • Resolution: Fixed
    • Priority: Icon: Major - P3 Major - P3
    • 8.1.0-rc0
    • Affects Version/s: None
    • Component/s: None
    • None
    • Query Execution
    • Fully Compatible
    • QE 2024-12-23
    • None
    • 0
    • None
    • None
    • None
    • None
    • None
    • None

      Create a new header src/mongo/db/exec/expression/evaluate.h and define a namespace mongo::exec::expression with a set of functions

      Value evaluate(const ExpressionFromAccumulator& expr, const Document& root, Variables* variables)

      one for each

      • ExpressionFromAccumulator<AccumulatorAvg>
      • ExpressionFromAccumulator<AccumulatorMax>
      • ExpressionFromAccumulator<AccumulatorMin>
      • ExpressionFromAccumulator<AccumulatorStdDevPop>
      • ExpressionFromAccumulator<AccumulatorStdDevSamp>
      • ExpressionFromAccumulator<AccumulatorSum>
      • ExpressionFromAccumulator<AccumulatorMergeObjects>
      • ExpressionFromAccumulatorN<AccumulatorMaxN>
      • ExpressionFromAccumulatorN<AccumulatorMinN>
      • ExpressionFromAccumulatorN<AccumulatorFirstN>
      • ExpressionFromAccumulatorN<AccumulatorLastN>
      • ExpressionFromAccumulatorQuantile<AccumulatorMedian>
      • ExpressionFromAccumulatorQuantile<AccumulatorPercentile>

      The body of the functions will be in a src/mongo/db/exec/expression/evaluate_accumulator.cpp and will be taken from the evaluate() method, and the evaluate() method will be changed so that it calls the new method.

       

            Assignee:
            alberto.massari@mongodb.com Alberto Massari
            Reporter:
            alberto.massari@mongodb.com Alberto Massari
            Votes:
            0 Vote for this issue
            Watchers:
            1 Start watching this issue

              Created:
              Updated:
              Resolved: