我有一个模型有“成员”,“组”,“成员”和“用户”.数据以树结构组织,其中包含与其关联的成员的组.没有任何组关联的成员被视为孤儿,对申请没有用处.
当用户销毁一个组时,不应该留下任何孤立的成员.换句话说:当且仅当最后一个组关联被删除时,才应销毁成员.优选地,这应该在单个事务中发生,但是最重要的方面是孤立对象不随时间累积在数据库中.
只应删除与该用户关联的成员和组.其他用户拥有的组,成员和成员资格不应受到任何影响. (有人可能认为可以随时运行全局清理方法,但我想隔离破坏性操作以仅影响当前用户对象.)
我的问题:在Rails 3中实现此功能的最有效和最优雅的方法是什么?我当前的实现(由此处描述的简化模型说明)不会从数据库中删除成员,除非用户手动删除它(或者通过级联删除删除整个用户及其所有数据).
class User < ActiveRecord::Base has_many :groups,:foreign_key => 'owner_id',:dependent => :delete_all has_many :members,:dependent => :destroy end class Member < ActiveRecord::Base belongs_to :owner,:class_name => 'User' has_many :memberships,:dependent => :destroy has_many :groups,:through => :memberships end class Membership < ActiveRecord::Base belongs_to :member belongs_to :group end class Group < ActiveRecord::Base belongs_to :owner,:class_name => 'User' belongs_to :parent,:class_name => 'Group' has_many :groups,:foreign_key => 'parent_id',:dependent => :destroy has_many :memberships,:dependent => :destroy has_many :members,:through => :memberships end
解决方法
我通过在Membership类中添加一个回调来解决这个问题,该类在会员资格被销毁时通知会员.如果成员对象不再具有任何组关联,则它将自行销毁.
class Membership < ActiveRecord::Base belongs_to :member belongs_to :group after_destroy :notify_member def notify_member member.destroy_if_empty_groups end end class Member < ActiveRecord::Base belongs_to :owner,:through => :memberships def destroy_if_empty_groups if groups.count == 0 self.destroy end end end
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。