aboutsummaryrefslogtreecommitdiffstats
path: root/spec/arel
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-09-24 10:24:31 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-24 10:24:31 -0700
commit58d82b23a102ca1eb5510b8c49bc097b402a332d (patch)
treefda2bba5863637d996cb0754aed767bd400397cd /spec/arel
parentf63badf42738c4a553e84e3d121786000c67c623 (diff)
downloadrails-58d82b23a102ca1eb5510b8c49bc097b402a332d.tar.gz
rails-58d82b23a102ca1eb5510b8c49bc097b402a332d.tar.bz2
rails-58d82b23a102ca1eb5510b8c49bc097b402a332d.zip
dealing with limits and offsets
Diffstat (limited to 'spec/arel')
-rw-r--r--spec/arel/visitors/oracle_spec.rb15
1 files changed, 15 insertions, 0 deletions
diff --git a/spec/arel/visitors/oracle_spec.rb b/spec/arel/visitors/oracle_spec.rb
index 87a1c378ac..07ac352893 100644
--- a/spec/arel/visitors/oracle_spec.rb
+++ b/spec/arel/visitors/oracle_spec.rb
@@ -25,6 +25,21 @@ module Arel
SELECT * FROM (SELECT ORDER BY foo) WHERE ROWNUM <= 10
}
end
+
+ it 'creates a different subquery when there is an offset' do
+ stmt = Nodes::SelectStatement.new
+ stmt.limit = 10
+ stmt.offset = Nodes::Offset.new(10)
+ sql = @visitor.accept stmt
+ sql.should be_like %{
+ SELECT * FROM (
+ SELECT raw_sql_.*, rownum raw_rnum_
+ FROM (SELECT ) raw_sql_
+ WHERE rownum <= 20
+ )
+ WHERE raw_rnum_ > 10
+ }
+ end
end
end
end