diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-04-03 12:06:23 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-04-03 12:06:23 +0000 |
commit | efb55d1cf50ba895b2811424b8df5e65f1205a66 (patch) | |
tree | 4eefcc45a9abd0096c9166e6487febf8dfecbd97 | |
parent | 4f6c943b05ea537be515ae6d70f8986191ef7e30 (diff) | |
download | rails-efb55d1cf50ba895b2811424b8df5e65f1205a66.tar.gz rails-efb55d1cf50ba895b2811424b8df5e65f1205a66.tar.bz2 rails-efb55d1cf50ba895b2811424b8df5e65f1205a66.zip |
Allow order, conditions, and joins in finds that include associations
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1080 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rwxr-xr-x | activerecord/lib/active_record/associations.rb | 11 | ||||
-rwxr-xr-x | activerecord/lib/active_record/base.rb | 7 | ||||
-rwxr-xr-x | activerecord/test/associations_test.rb | 4 |
3 files changed, 17 insertions, 5 deletions
diff --git a/activerecord/lib/active_record/associations.rb b/activerecord/lib/active_record/associations.rb index ba6a0ab89b..956589fa84 100755 --- a/activerecord/lib/active_record/associations.rb +++ b/activerecord/lib/active_record/associations.rb @@ -621,7 +621,7 @@ module ActiveRecord def find_with_associations(options = {}) reflections = [ options[:include] ].flatten.collect { |association| reflect_on_association(association) } - rows = connection.select_all(construct_finder_sql_with_included_associations(reflections), "#{name} Load Including Associations") + rows = connection.select_all(construct_finder_sql_with_included_associations(options, reflections), "#{name} Load Including Associations") records = rows.collect { |row| instantiate(extract_record(table_name, row)) }.uniq reflections.each do |reflection| @@ -638,14 +638,19 @@ module ActiveRecord return records end - def construct_finder_sql_with_included_associations(reflections) + def construct_finder_sql_with_included_associations(options, reflections) sql = "SELECT #{selected_columns(table_name, columns)}" reflections.each { |reflection| sql << ", #{selected_columns(reflection.klass.table_name, reflection.klass.columns)}" } sql << " FROM #{table_name} " + reflections.each do |reflection| sql << " LEFT JOIN #{reflection.klass.table_name} ON " + - "#{reflection.klass.table_name}.#{table_name.classify.foreign_key} = #{table_name}.#{primary_key}" + "#{reflection.klass.table_name}.#{table_name.classify.foreign_key} = #{table_name}.#{primary_key} " end + + sql << "#{options[:joins]} " if options[:joins] + add_conditions!(sql, options[:conditions]) + sql << "ORDER BY #{options[:order]} " if options[:order] return sanitize_sql(sql) end diff --git a/activerecord/lib/active_record/base.rb b/activerecord/lib/active_record/base.rb index 70004ec458..df42303905 100755 --- a/activerecord/lib/active_record/base.rb +++ b/activerecord/lib/active_record/base.rb @@ -706,14 +706,17 @@ module ActiveRecord #:nodoc: sql << "#{options[:joins]} " if options[:joins] add_conditions!(sql, options[:conditions]) sql << "ORDER BY #{options[:order]} " if options[:order] + add_limit!(sql, options) + + return sql + end + def add_limit!(sql, options) if options[:limit] && options[:offset] connection.add_limit_with_offset!(sql, options[:limit].to_i, options[:offset].to_i) elsif options[:limit] connection.add_limit_without_offset!(sql, options[:limit].to_i) end - - return sql end # Adds a sanitized version of +conditions+ to the +sql+ string. Note that it's the passed +sql+ string is changed. diff --git a/activerecord/test/associations_test.rb b/activerecord/test/associations_test.rb index 68245379ed..e1a05e481b 100755 --- a/activerecord/test/associations_test.rb +++ b/activerecord/test/associations_test.rb @@ -539,6 +539,10 @@ class HasManyAssociationsTest < Test::Unit::TestCase posts = Post.find(:all, :include => :comments) assert_equal 2, posts.first.comments.size assert_equal @greetings.body, posts.first.comments.first.body + + post = Post.find(:first, :include => :comments, :conditions => "posts.title = 'Welcome to the weblog'") + assert_equal 2, post.comments.size + assert_equal @greetings.body, post.comments.first.body end def test_eager_association_loading_with_multiple_associations |