是否可以使用 Observer 来观察 JOIN 记录的创建?例如,您有一个用户模型 has_and_belongs_to_many Book Models。是否可以在创建或删除 books_users 记录时监控它们,或者我必须有 BookUser 模型才能执行此操作?
我想观察的例子:
User.books << book
或
User.books.push(book)
或 随便!
谢谢,
戴夫·K。
最佳答案
这就是您应该使用 has_many :through 而不是 has_and_belongs_to 的确切原因;它允许您创建一个 BookUser 模型,其中可以使用常规的 activerecord 回调/观察者(例如 after_save)。该站点更好地解释了差异,http://blog.hasmanythrough.com/2006/4/20/many-to-many-dance-off
关于ruby-on-rails - rails : How to observe join records that don't actually have a Model?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/398673/