Class: Sequel::SQL::OrderedExpression

Inherits:
Expression show all
Defined in:
lib/sequel/sql.rb,
lib/sequel/extensions/eval_inspect.rb

Overview

Represents a column/expression to order the result set by.

Constant Summary collapse

INVERT_NULLS =
{:first=>:last, :last=>:first}.freeze

Instance Attribute Summary collapse

Instance Method Summary collapse

Methods inherited from Expression

#==, attr_reader, #clone, #eql?, #hash, inherited, #inspect

Constructor Details

#initialize(expression, descending = true, opts = OPTS) ⇒ OrderedExpression

Set the expression and descending attributes to the given values. Options:

:nulls

Can be :first/:last for NULLS FIRST/LAST.


1682
1683
1684
1685
1686
1687
# File 'lib/sequel/sql.rb', line 1682

def initialize(expression, descending = true, opts=OPTS)
  @expression = expression
  @descending = descending
  @nulls = opts[:nulls]
  freeze
end

Instance Attribute Details

#descendingObject (readonly)

Whether the expression should order the result set in a descending manner


1673
1674
1675
# File 'lib/sequel/sql.rb', line 1673

def descending
  @descending
end

#expressionObject (readonly)

The expression to order the result set by.


1670
1671
1672
# File 'lib/sequel/sql.rb', line 1670

def expression
  @expression
end

#nullsObject (readonly)

Whether to sort NULLS FIRST/LAST


1676
1677
1678
# File 'lib/sequel/sql.rb', line 1676

def nulls
  @nulls
end

Instance Method Details

#ascObject

Return a copy that is ordered ASC


1690
1691
1692
# File 'lib/sequel/sql.rb', line 1690

def asc
  OrderedExpression.new(@expression, false, :nulls=>@nulls)
end

#descObject

Return a copy that is ordered DESC


1695
1696
1697
# File 'lib/sequel/sql.rb', line 1695

def desc
  OrderedExpression.new(@expression, true, :nulls=>@nulls)
end

#invertObject

Return an inverted expression, changing ASC to DESC and NULLS FIRST to NULLS LAST.


1700
1701
1702
# File 'lib/sequel/sql.rb', line 1700

def invert
  OrderedExpression.new(@expression, !@descending, :nulls=>INVERT_NULLS.fetch(@nulls, @nulls))
end