1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Support columns_for_distinct

This commit is contained in:
Yasuo Honda 2013-06-06 21:33:20 +09:00
parent bd6adc877a
commit 51f5bece08
2 changed files with 4 additions and 3 deletions

View file

@ -8,7 +8,7 @@ module Arel
# if need to select first records without ORDER BY and GROUP BY and without DISTINCT # if need to select first records without ORDER BY and GROUP BY and without DISTINCT
# then can use simple ROWNUM in WHERE clause # then can use simple ROWNUM in WHERE clause
if o.limit && o.orders.empty? && !o.offset && o.cores.first.projections.first !~ /^DISTINCT / if o.limit && o.orders.empty? && !o.offset && o.cores.first.set_quantifier.class.to_s !~ /Distinct/
o.cores.last.wheres.push Nodes::LessThanOrEqual.new( o.cores.last.wheres.push Nodes::LessThanOrEqual.new(
Nodes::SqlLiteral.new('ROWNUM'), o.limit.expr Nodes::SqlLiteral.new('ROWNUM'), o.limit.expr
) )
@ -83,7 +83,7 @@ module Arel
return o if o.orders.empty? return o if o.orders.empty?
return o unless o.cores.any? do |core| return o unless o.cores.any? do |core|
core.projections.any? do |projection| core.projections.any? do |projection|
/DISTINCT.*FIRST_VALUE/ === projection /FIRST_VALUE/ === projection
end end
end end
# Previous version with join and split broke ORDER BY clause # Previous version with join and split broke ORDER BY clause

View file

@ -85,7 +85,8 @@ module Arel
it 'creates a subquery when there is DISTINCT' do it 'creates a subquery when there is DISTINCT' do
stmt = Nodes::SelectStatement.new stmt = Nodes::SelectStatement.new
stmt.cores.first.projections << Nodes::SqlLiteral.new('DISTINCT id') stmt.cores.first.set_quantifier = Arel::Nodes::Distinct.new
stmt.cores.first.projections << Nodes::SqlLiteral.new('id')
stmt.limit = Arel::Nodes::Limit.new(10) stmt.limit = Arel::Nodes::Limit.new(10)
sql = @visitor.accept stmt sql = @visitor.accept stmt
sql.must_be_like %{ sql.must_be_like %{