通过关联在has_many上实现软删除的最简单方法是什么?
我想要的是这样的:
class Company > ActiveRecord::Base has_many :staffings has_many :users,through: :staffings,conditions: {staffings: {active: true}} end
我想通过以下方式使用Company#users:
>公司#用户应该是正常的关联,以便它与表格一起使用,并且不会破坏现有合同.
>将用户添加到公司时,会创建一个具有active:true的新Staffing.
>从公司中删除用户时,现有人员配置将更新为活动:false(当前只是被删除).
>将以前删除的用户添加到公司时(以便Staffing #active == false),Staffing将更新为active:true.
我考虑过覆盖公司#useuse =方法,但它确实不够好,因为还有其他更新关联的方法.
所以问题是:如何在公司#用户协会上实现解释的行为?
谢谢.
解决方法
has_many:通过关联实际上只是语法糖.当你需要做繁重的工作时,我会建议拆分逻辑并提供适当的方法和范围.了解如何覆盖
callbacks对于此类事情也很有用.
class Company < ActiveRecord::Base has_many :staffings has_many :users,conditions: ['staffings.active = ?',true] end class Staffing < ActiveRecord::Base belongs_to :company has_one :user end class User < ActiveRecord::Base belongs_to :staffing # after callback fires,create a staffing after_create {|user| user.create_staffing(active: true)} # override the destroy method since you # don't actually want to destroy the User def destroy run_callbacks :delete do self.staffing.active = false if self.staffing end end end
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。