我有一个模型有"成员","组","成员"和"用户".数据以树结构组织,其中包含与其关联的成员的组.没有任何组关联的成员被视为孤儿,对申请没有用处.
当用户销毁一个组时,不应该留下任何孤立的成员.换句话说:当且仅当最后一个组关联被删除时,才应销毁成员.优选地,这应该在单个事务中发生,但是最重要的方面是孤立对象不随时间累积在数据库中.
只应删除与该用户关联的成员和组.其他用户拥有的组,成员和成员资格不应受到任何影响.(有人可能认为可以随时运行全局清理方法,但我想隔离破坏性操作以仅影响当前用户对象.)
我的问题:在Rails 3中实现此功能的最有效和最优雅的方法是什么?我当前的实现(由此处描述的简化模型说明)不会从数据库中删除成员,除非用户手动删除它(或者通过级联删除删除整个用户及其所有数据).
class User < ActiveRecord::Base
has_many :groups, :foreign_key => 'owner_id', :dependent => :delete_all
has_many :members, :foreign_key => 'owner_id', :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 …Run Code Online (Sandbox Code Playgroud)