Class: ConceptQL::Nodes::Sum
- Defined in:
- lib/conceptql/nodes/sum.rb
Constant Summary
Constants inherited from Node
Instance Attribute Summary
Attributes inherited from Node
Instance Method Summary collapse
Methods inherited from PassThru
Methods inherited from Node
#arguments, #children, #columns, #evaluate, #initialize, #select_it, #sql, #stream, #types
Constructor Details
This class inherits a constructor from ConceptQL::Nodes::Node
Instance Method Details
#query(db) ⇒ Object
6 7 8 9 10 11 12 13 14 |
# File 'lib/conceptql/nodes/sum.rb', line 6 def query(db) db.from(unioned(db)) .select_group(*(COLUMNS - [:start_date, :end_date, :criterion_id, :value_as_numeric])) .select_append(Sequel.lit('?', 0).as(:criterion_id)) .select_append{ min(start_date).as(:start_date) } .select_append{ max(end_date).as(:end_date) } .select_append{sum(value_as_numeric).as(:value_as_numeric)} .from_self end |
#unioned(db) ⇒ Object
16 17 18 19 20 |
# File 'lib/conceptql/nodes/sum.rb', line 16 def unioned(db) children.map { |c| c.evaluate(db) }.inject do |uni, q| uni.union(q) end end |