如果活动记录中不存在,则创建功能?



我正在使用Rails 3.2.8。 如果状态记录尚不存在,我需要创建状态记录。如果存在状态记录,我什么都不做。所以我的代码是这样的:

user_level_status = UserLevelStatus.where(user_id: user_id, level_id: level_id).first
if !user_level_status
  UserLevelStatus.create(user_id: user_id, level_id: level_id, status: UserLevelStatus::READY)
end

有没有更好的方法来在Rails/ActiveRecord中处理这个问题?是否有与find_or_create_by_等效的机制?我可以使用find_or_create_by_user_id并检查level_id吗?我只会丢弃结果,所以即使这样也不是那么优雅。

是的,有。

导轨 3

user_level_status = UserLevelStatus.find_or_create_by_user_id_and_level_id(user_id, level_id)

导轨 4:

user_level_status = UserLevelStatus.find_or_create_by(user_id: user_id, level_id: level_id)

您应该在模型中设置默认status

你应该

使用

UserLevelStatus.where(user_id: user_id, level_id: level_id).first_or_create(status: UserLevelStatus::READY)

使用 find_or_create_*

hash = {user_id: user_id, level_id: level_id, status: UserLevelStatus::READY}
UserLevelStatus.find_or_create_by_user_id_and_level_id_and_status(hash)

已编辑 对于您的情况,您应该使用以下

hash = {user_id: user_id, level_id: level_id}
UserLevelStatus.find(:first, :conditions => hash) || UserLevelStatus.create(hash.merge({status: UserLevelStatus::READY}) 

另一种选择是

UserLevelStatus.where(user_id: user_id, level_id: level_id).first ||
  UserLevelStatus.create(user_id: user_id, level_id: level_id, status: UserLevelStatus::READY)

最新更新