diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-01-25 10:04:49 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-01-25 10:04:49 +0000 |
commit | fd67e3befc748e91b4ad0b09be7f3cca69bb7380 (patch) | |
tree | a8156cdaef342b66ae39482e0168fd59ef525328 /activerecord | |
parent | 453bc7346deb7ed9ec41067913a727bdbcc5f5a7 (diff) | |
download | rails-fd67e3befc748e91b4ad0b09be7f3cca69bb7380.tar.gz rails-fd67e3befc748e91b4ad0b09be7f3cca69bb7380.tar.bz2 rails-fd67e3befc748e91b4ad0b09be7f3cca69bb7380.zip |
The create and build methods are only available for has_one/belongs_to if an association already exist. It will not work when it's nil. Updated the documentation to reflect that.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@501 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord')
-rwxr-xr-x | activerecord/lib/active_record/associations.rb | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/activerecord/lib/active_record/associations.rb b/activerecord/lib/active_record/associations.rb index afd1a0cb45..b9cae482aa 100755 --- a/activerecord/lib/active_record/associations.rb +++ b/activerecord/lib/active_record/associations.rb @@ -35,7 +35,6 @@ module ActiveRecord # The project class now has the following methods (and more) to ease the traversal and manipulation of its relationships: # * <tt>Project#portfolio, Project#portfolio=(portfolio), Project#portfolio.nil?</tt> # * <tt>Project#project_manager, Project#project_manager=(project_manager), Project#project_manager.nil?,</tt> - # <tt>Project#project_manager.build, Project#project_manager.create</tt> # * <tt>Project#milestones.empty?, Project#milestones.size, Project#milestones, Project#milestones<<(milestone),</tt> # <tt>Project#milestones.delete(milestone), Project#milestones.find(milestone_id), Project#milestones.find_all(conditions),</tt> # <tt>Project#milestones.build, Project#milestones.create</tt> @@ -249,9 +248,11 @@ module ActiveRecord # and saves the associate object. # * <tt>association.nil?</tt> - returns true if there is no associated object. # * <tt>association.build(attributes = {})</tt> - returns a new object of the associated type that has been instantiated - # with +attributes+ and linked to this object through a foreign key but has not yet been saved. + # with +attributes+ and linked to this object through a foreign key but has not yet been saved. Note: This ONLY works if + # an association already exists. It will NOT work if the association is nil. # * <tt>association.create(attributes = {})</tt> - returns a new object of the associated type that has been instantiated # with +attributes+ and linked to this object through a foreign key and that has already been saved (if it passed the validation). + # Note: This ONLY works if an association already exists. It will NOT work if the association is nil. # # Example: An Account class declares <tt>has_one :beneficiary</tt>, which will add: # * <tt>Account#beneficiary</tt> (similar to <tt>Beneficiary.find_first "account_id = #{id}"</tt>) |