Class: SPARQL::Algebra::Operator::Order
- Inherits:
-
Binary
- Object
- SPARQL::Algebra::Operator
- Binary
- SPARQL::Algebra::Operator::Order
- Includes:
- Query
- Defined in:
- vendor/bundler/ruby/3.3.0/bundler/gems/sparql-36baa432eb7f/lib/sparql/algebra/operator/order.rb
Overview
The SPARQL GraphPattern order
operator.
[23] OrderClause ::= 'ORDER' 'BY' OrderCondition+
Constant Summary collapse
- NAME =
[:order]
Constants inherited from Binary
Constants inherited from SPARQL::Algebra::Operator
Constants included from Expression
Constants included from RDF::Util::Logger
Instance Attribute Summary
Attributes included from Query
Attributes inherited from SPARQL::Algebra::Operator
Instance Method Summary collapse
-
#execute(queryable, **options) {|solution| ... } ⇒ RDF::Query::Solutions
Executes this query on the given
queryable
graph or repository. -
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Query
#each_solution, #empty?, #failed?, #graph_name=, #matched?, #query_yields_boolean?, #query_yields_solutions?, #query_yields_statements?, #unshift, #variables
Methods inherited from Binary
Methods inherited from SPARQL::Algebra::Operator
#aggregate?, arity, base_uri, #base_uri, base_uri=, #bind, #boolean, #constant?, #deep_dup, #each_descendant, #eql?, #evaluatable?, evaluate, #executable?, #first_ancestor, for, #formulae, #initialize, #inspect, #ndvars, #node?, #operand, #optimize, #optimize!, #parent, #parent=, prefixes, #prefixes, prefixes=, #rewrite, #to_binary, to_sparql, #to_sxp, #to_sxp_bin, #validate!, #variable?, #variables, #vars
Methods included from Expression
cast, #constant?, #evaluate, extension, extension?, extensions, for, #invalid?, new, #node?, open, #optimize, #optimize!, parse, register_extension, #to_sxp_bin, #valid?, #validate!, #variable?
Methods included from RDF::Util::Logger
#log_debug, #log_depth, #log_error, #log_fatal, #log_info, #log_recover, #log_recovering?, #log_statistics, #log_warn, #logger
Constructor Details
This class inherits a constructor from SPARQL::Algebra::Operator::Binary
Instance Method Details
#execute(queryable, **options) {|solution| ... } ⇒ RDF::Query::Solutions
Executes this query on the given queryable
graph or repository.
Orders a solution set returned by executing operand(1) using
an array of expressions and/or variables specified in operand(0)
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 |
# File 'vendor/bundler/ruby/3.3.0/bundler/gems/sparql-36baa432eb7f/lib/sparql/algebra/operator/order.rb', line 86 def execute(queryable, **, &block) debug() {"Order"} @solutions = queryable.query(operands.last, **.merge(depth: [:depth].to_i + 1)).order do |a, b| operand(0).inject(0) do |memo, op| debug() {"(order) #{op.inspect}"} memo = begin a_eval = op.evaluate(a, queryable: queryable, **.merge(depth: [:depth].to_i + 1)) rescue nil b_eval = op.evaluate(b, queryable: queryable, **.merge(depth: [:depth].to_i + 1)) rescue nil comp = begin Operator::Compare.evaluate(a_eval, b_eval, order_by: true).to_s.to_i rescue TypeError # Type sError is effectively zero debug() {"(order) rescue(#{$!}): #{a_eval.inspect}, #{b_eval.inspect}"} RDF::Literal(0) end comp = -comp if op.is_a?(Operator::Desc) comp end if memo == 0 memo end end @solutions.each(&block) if block_given? @solutions end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Provides order to descendant query.
119 120 121 |
# File 'vendor/bundler/ruby/3.3.0/bundler/gems/sparql-36baa432eb7f/lib/sparql/algebra/operator/order.rb', line 119 def to_sparql(**) operands.last.to_sparql(order_ops: operands.first, **) end |