mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Allow #nulls_first and #nulls_last in PostgreSQL
When using PostgreSQL, it's useful to be able to specify NULLS FIRST and NULLS LAST on ordered columns. With this commit you can do that now, as in: ```ruby User.arel_table[:first_name].desc.nulls_last ```
This commit is contained in:
parent
3c28e79b61
commit
66b19b5dec
5 changed files with 45 additions and 1 deletions
|
@ -18,6 +18,7 @@ require "arel/nodes/false"
|
||||||
# unary
|
# unary
|
||||||
require "arel/nodes/unary"
|
require "arel/nodes/unary"
|
||||||
require "arel/nodes/grouping"
|
require "arel/nodes/grouping"
|
||||||
|
require "arel/nodes/ordering"
|
||||||
require "arel/nodes/ascending"
|
require "arel/nodes/ascending"
|
||||||
require "arel/nodes/descending"
|
require "arel/nodes/descending"
|
||||||
require "arel/nodes/unqualified_column"
|
require "arel/nodes/unqualified_column"
|
||||||
|
|
18
activerecord/lib/arel/nodes/ordering.rb
Normal file
18
activerecord/lib/arel/nodes/ordering.rb
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
module Arel # :nodoc: all
|
||||||
|
module Nodes
|
||||||
|
class Ordering < Unary
|
||||||
|
def nulls_first
|
||||||
|
NullsFirst.new(self)
|
||||||
|
end
|
||||||
|
|
||||||
|
def nulls_last
|
||||||
|
NullsLast.new(self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class NullsFirst < Ordering; end
|
||||||
|
class NullsLast < Ordering; end
|
||||||
|
end
|
||||||
|
end
|
|
@ -36,7 +36,6 @@ module Arel # :nodoc: all
|
||||||
Offset
|
Offset
|
||||||
On
|
On
|
||||||
OptimizerHints
|
OptimizerHints
|
||||||
Ordering
|
|
||||||
RollUp
|
RollUp
|
||||||
}.each do |name|
|
}.each do |name|
|
||||||
const_set(name, Class.new(Unary))
|
const_set(name, Class.new(Unary))
|
||||||
|
|
|
@ -82,6 +82,16 @@ module Arel # :nodoc: all
|
||||||
visit o.right, collector
|
visit o.right, collector
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def visit_Arel_Nodes_NullsFirst(o, collector)
|
||||||
|
visit o.expr, collector
|
||||||
|
collector << " NULLS FIRST"
|
||||||
|
end
|
||||||
|
|
||||||
|
def visit_Arel_Nodes_NullsLast(o, collector)
|
||||||
|
visit o.expr, collector
|
||||||
|
collector << " NULLS LAST"
|
||||||
|
end
|
||||||
|
|
||||||
# Used by Lateral visitor to enclose select queries in parentheses
|
# Used by Lateral visitor to enclose select queries in parentheses
|
||||||
def grouping_parentheses(o, collector)
|
def grouping_parentheses(o, collector)
|
||||||
if o.expr.is_a? Nodes::SelectStatement
|
if o.expr.is_a? Nodes::SelectStatement
|
||||||
|
|
|
@ -315,6 +315,22 @@ module Arel
|
||||||
_(sql).must_be_like %{ "users"."name" IS DISTINCT FROM NULL }
|
_(sql).must_be_like %{ "users"."name" IS DISTINCT FROM NULL }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "Nodes::Ordering" do
|
||||||
|
it "should handle nulls first" do
|
||||||
|
test = Table.new(:users)[:first_name].desc.nulls_first
|
||||||
|
_(compile(test)).must_be_like %{
|
||||||
|
"users"."first_name" DESC NULLS FIRST
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
it "should handle nulls last" do
|
||||||
|
test = Table.new(:users)[:first_name].desc.nulls_last
|
||||||
|
_(compile(test)).must_be_like %{
|
||||||
|
"users"."first_name" DESC NULLS LAST
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue