我有一个带有“member”、“group”、“membership”和“user”的模型。数据以树状结构组织,其中包含与其相关联的成员的组。没有任何组关联的成员被认为是孤立的,对应用程序没有用处。
当用户销毁组时,不应留下任何孤立的成员。换句话说:当且仅当最后一个组关联被删除时,才应该销毁成员。最好这应该发生在单个事务中,但最重要的方面是孤立对象不会随着时间的推移在数据库中累积。
仅应删除与用户关联的成员和组。其他用户拥有的组、成员和成员资格完全不受影响。(有人可能会争辩说可以随时运行全局清理方法,但我想隔离破坏性操作以仅影响当前用户对象。)
我的问题:在 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 => :destroy
has_many :members, :through => :memberships
end