Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Rails: dependent: :destroy - How does this work?

In an example where there is an association of Owner that is as fellows:

class Owner < ActiveRecord::Base
  has_many :buildings, dependent: :destroy 
end

The other side of relationship:

class Building < ActiveRecord::Base
  belongs_to :owner
end

If I were to delete an Owner, would it destroy the associated Building(s) as well? How can I specify a dependent relationship so that the owner and primary key is no longer associated with any Building(s) if I delete an Owner?

like image 455
John Avatar asked Dec 16 '22 02:12

John


1 Answers

You probably want :nullify. See the Rails docs for has_many.

:dependent controls what happens to the associated objects when their owner is destroyed. Note that these are implemented as callbacks, and Rails executes callbacks in order. Therefore, other similar callbacks may affect the :dependent behavior, and the :dependent behavior may affect other callbacks.

:destroy causes all the associated objects to also be destroyed.

:delete_all causes all the associated objects to be deleted directly from the database (so callbacks will not be executed).

:nullify causes the foreign keys to be set to NULL. Callbacks are not executed.

:restrict_with_exception causes an exception to be raised if there are any associated records.

:restrict_with_error causes an error to be added to the owner if there are any associated objects.

If using with the :through option, the association on the join model must be a belongs_to, and the records which get deleted are the join records, rather than the associated records.

like image 89
Philip Hallstrom Avatar answered Dec 29 '22 00:12

Philip Hallstrom