aboutsummaryrefslogtreecommitdiffstats
path: root/guides/source
diff options
context:
space:
mode:
authorBart de Water <bartdewater@gmail.com>2017-12-14 08:22:25 -0500
committerBart de Water <bartdewater@gmail.com>2018-01-10 11:59:24 -0500
commit4ab4364a51e7e95c15eaa09fc6b7234afcfbc6f4 (patch)
tree458ba7ffe5ef414d8a898671b1183185b03f89fb /guides/source
parent5a593486f5c8a73f2be200a409b0a14dff51790c (diff)
downloadrails-4ab4364a51e7e95c15eaa09fc6b7234afcfbc6f4.tar.gz
rails-4ab4364a51e7e95c15eaa09fc6b7234afcfbc6f4.tar.bz2
rails-4ab4364a51e7e95c15eaa09fc6b7234afcfbc6f4.zip
[ci skip] setting :inverse_of works with :as, :through and :polymorphic options, and is needed for bi-directionality with a scope
[ci skip] Remove :conditions opion from association basics guide This got replaced by scopes.
Diffstat (limited to 'guides/source')
-rw-r--r--guides/source/association_basics.md26
1 files changed, 9 insertions, 17 deletions
diff --git a/guides/source/association_basics.md b/guides/source/association_basics.md
index b5e236b790..fa522f2eaf 100644
--- a/guides/source/association_basics.md
+++ b/guides/source/association_basics.md
@@ -735,12 +735,9 @@ a.first_name = 'David'
a.first_name == b.author.first_name # => true
```
-Active Record supports automatic identification for most associations with standard names. However, Active Record will not automatically identify bi-directional associations that contain any of the following options:
+Active Record supports automatic identification for most associations with standard names. However, Active Record will not automatically identify bi-directional associations that contain a scope or any of the following options:
-* `:conditions`
* `:through`
-* `:polymorphic`
-* `:class_name`
* `:foreign_key`
For example, consider the following model declarations:
@@ -787,12 +784,6 @@ a.first_name = 'David'
a.first_name == b.writer.first_name # => true
```
-There are a few limitations to `:inverse_of` support:
-
-* They do not work with `:through` associations.
-* They do not work with `:polymorphic` associations.
-* They do not work with `:as` associations.
-
Detailed Association Reference
------------------------------
@@ -1012,7 +1003,7 @@ When we execute `@user.todos.create` then the `@todo` record will have its
##### `:inverse_of`
-The `:inverse_of` option specifies the name of the `has_many` or `has_one` association that is the inverse of this association. Does not work in combination with the `:polymorphic` options.
+The `:inverse_of` option specifies the name of the `has_many` or `has_one` association that is the inverse of this association.
```ruby
class Author < ApplicationRecord
@@ -1066,7 +1057,8 @@ There may be times when you wish to customize the query used by `belongs_to`. Su
```ruby
class Book < ApplicationRecord
belongs_to :author, -> { where active: true },
- dependent: :destroy
+ dependent: :destroy,
+ inverse_of: :books
end
```
@@ -1082,8 +1074,8 @@ You can use any of the standard [querying methods](active_record_querying.html)
The `where` method lets you specify the conditions that the associated object must meet.
```ruby
-class book < ApplicationRecord
- belongs_to :author, -> { where active: true }
+class Book < ApplicationRecord
+ belongs_to :author, -> { where active: true }, inverse_of: :books
end
```
@@ -1299,7 +1291,7 @@ TIP: In any case, Rails will not create foreign key columns for you. You need to
##### `:inverse_of`
-The `:inverse_of` option specifies the name of the `belongs_to` association that is the inverse of this association. Does not work in combination with the `:through` or `:as` options.
+The `:inverse_of` option specifies the name of the `belongs_to` association that is the inverse of this association.
```ruby
class Supplier < ApplicationRecord
@@ -1337,7 +1329,7 @@ There may be times when you wish to customize the query used by `has_one`. Such
```ruby
class Supplier < ApplicationRecord
- has_one :account, -> { where active: true }
+ has_one :account, -> { where active: true }, inverse_of: :supplier
end
```
@@ -1694,7 +1686,7 @@ TIP: In any case, Rails will not create foreign key columns for you. You need to
##### `:inverse_of`
-The `:inverse_of` option specifies the name of the `belongs_to` association that is the inverse of this association. Does not work in combination with the `:through` or `:as` options.
+The `:inverse_of` option specifies the name of the `belongs_to` association that is the inverse of this association.
```ruby
class Author < ApplicationRecord