当前位置:  开发笔记 > 编程语言 > 正文

限制has_many关系中的关联数量的最佳实践?

如何解决《限制has_many关系中的关联数量的最佳实践?》经验,为你挑选了1个好方法。

假设我有两个模型 - 用户和帐户.每个帐户最多可以有n个与之关联的用户,而用户只能与一个帐户关联.

用户说,这似乎很自然

belongs_to :account

和帐户

has_many :users

但是,在通过has_many声明来限制关联数量时,我不清楚最佳实践.我知道有一个:limit参数,但这只限制了返回的关联数,而不是可以存在的数量.

我怀疑答案是使用类似:before_add.但是,这种方法似乎只适用于通过<<创建的关联.所以当你使用时它会被调用

@account.users << someuser 

但如果你使用的话就没有

@account.users.create

我还认为在User模型中使用before_save实现限制可能更实际,但似乎在User模型中实现Account业务规则有点偏差.

限制关联数量的最佳做法是什么?

编辑:每个帐户的n个用户将是存储在各个帐户中的一些商业数据,而不是在代码中无处不在的直接幻数.



1> Raimonds Sim..:

首先,如果您的users表具有外键account_id,那么您需要使用

class User
  belongs_to :account
end

通过这种方式,您将确保用户只能与一个帐户关联.

如果您想限制该帐户最多可以拥有3个用户,那么您可以定义以下验证:

class User
  validates_each :account do |user, attr, value|
    user.errors.add attr, "too much users for account" if user.account.users.size >= 3
  end
end

因此,如果帐户已有3个用户,您将无法为帐户创建新用户.

推荐阅读
echo7111436
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有