diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-04-03 17:50:11 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-04-03 17:50:11 +0000 |
commit | f8783abf0cd409d53e7e104b576d45966252378b (patch) | |
tree | 2f8a0e604a7639e0b7983631208a7e7360928be0 /activerecord/lib/active_record/associations | |
parent | 46f2b03eacf5dd39c9283697d7d05f0ccb5f4a72 (diff) | |
download | rails-f8783abf0cd409d53e7e104b576d45966252378b.tar.gz rails-f8783abf0cd409d53e7e104b576d45966252378b.tar.bz2 rails-f8783abf0cd409d53e7e104b576d45966252378b.zip |
Made eager loading work even more
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1083 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/lib/active_record/associations')
-rw-r--r-- | activerecord/lib/active_record/associations/has_many_association.rb | 22 | ||||
-rw-r--r-- | activerecord/lib/active_record/associations/has_one_association.rb | 2 |
2 files changed, 10 insertions, 14 deletions
diff --git a/activerecord/lib/active_record/associations/has_many_association.rb b/activerecord/lib/active_record/associations/has_many_association.rb index 01374bd55a..f6bceee93a 100644 --- a/activerecord/lib/active_record/associations/has_many_association.rb +++ b/activerecord/lib/active_record/associations/has_many_association.rb @@ -50,17 +50,13 @@ module ActiveRecord end def find(*args) - # Return an Array if multiple ids are given. - expects_array = args.first.kind_of?(Array) - - ids = args.flatten.compact.uniq - - # If no ids given, raise RecordNotFound. - if ids.empty? - raise RecordNotFound, "Couldn't find #{@association_class.name} without an ID" + options = Base.send(:extract_options_from_args!, args) # If using a custom finder_sql, scan the entire collection. - elsif @options[:finder_sql] + if @options[:finder_sql] + expects_array = args.first.kind_of?(Array) + ids = args.flatten.compact.uniq + if ids.size == 1 id = ids.first record = load_target.detect { |record| id == record.id } @@ -68,11 +64,11 @@ module ActiveRecord else load_target.select { |record| ids.include?(record.id) } end - - # Otherwise, delegate to association class with conditions. else - args << { :conditions => "#{@association_class_primary_key_name} = #{@owner.quoted_id} #{@conditions ? " AND " + @conditions : ""}" } - @association_class.find(*args) + original_conditions = options[:conditions] ? " AND #{options[:conditions]}" : "" + options[:conditions] = + "#{@association_class_primary_key_name} = #{@owner.quoted_id} #{@conditions ? " AND " + @conditions : ""}#{original_conditions}" + @association_class.find(args.size == 1 ? args.first : args, options) end end diff --git a/activerecord/lib/active_record/associations/has_one_association.rb b/activerecord/lib/active_record/associations/has_one_association.rb index e566089013..f3c3515055 100644 --- a/activerecord/lib/active_record/associations/has_one_association.rb +++ b/activerecord/lib/active_record/associations/has_one_association.rb @@ -38,7 +38,7 @@ module ActiveRecord private def find_target - @association_class.find_first(@finder_sql, @options[:order]) + @association_class.find(:first, :conditions => @finder_sql, :order => @options[:order]) end def target_obsolete? |