Class: SPARQL::Algebra::Operator::Asc

Inherits:
Operator::Unary
  • Object
show all
Includes:
Evaluatable
Defined in:
lib/sparql/algebra/operator/asc.rb

Overview

The SPARQL ascending sort operator.

[24] OrderCondition ::= ( ( 'ASC' | 'DESC' ) BrackettedExpression ) | ( Constraint | Var )

Examples:

SPARQL Query

PREFIX foaf:    <http://xmlns.com/foaf/0.1/>
SELECT ?name
WHERE { ?x foaf:name ?name }
ORDER BY ASC(?name)

SSE

(prefix ((foaf: <http://xmlns.com/foaf/0.1/>))
  (project (?name)
    (order ((asc ?name))
      (bgp (triple ?x foaf:name ?name)))))

See Also:

Constant Summary collapse

NAME =
:asc

Instance Method Summary collapse

Methods included from Evaluatable

#apply, #memoize, #replace_aggregate!, #replace_vars!

Instance Method Details

#evaluate(bindings, **options) ⇒ RDF::Term

Returns the evaluation of its operand. Default comparison is in ascending order. Ordering is applied in Order.

Parameters:

  • bindings (RDF::Query::Solution)

    a query solution containing zero or more variable bindings

  • options (Hash{Symbol => Object})

    ({}) options passed from query

Returns:



35
36
37
# File 'lib/sparql/algebra/operator/asc.rb', line 35

def evaluate(bindings, **options)
  operand(0).evaluate(bindings, **options.merge(depth: options[:depth].to_i + 1))
end

#to_sparql(**options) ⇒ String

Returns a partial SPARQL grammar for this operator.

Provides order to descendant query.

Returns:

  • (String)


46
47
48
# File 'lib/sparql/algebra/operator/asc.rb', line 46

def to_sparql(**options)
  "ASC(#{operands.last.to_sparql(**options)})"
end