首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails ActiveRecord回调:如果存在更新,创建if不存在

Rails ActiveRecord回调:如果存在更新,创建if不存在
EN

Stack Overflow用户
提问于 2017-12-05 14:41:34
回答 1查看 720关注 0票数 0

在梳理完文档之后,我很难理解我应该使用什么回调。

伪码:

如果child_id和outage_id不存在

创建关系(INSERT语句)

如果outage_id被更改

修改关系(UPDATE语句)

这些插入和更新是通过collection_check_boxes处理的。

有3种模式。关系,断电,和孩子。

代码语言:javascript
复制
class Outage < ApplicationRecord
  has_many :relationships
  has_many :children, through: :relationships
end

class Child < ApplicationRecord
end


class Relationship < ApplicationRecord
  belongs_to :outage
  belongs_to :child

  validate :check_if_exists, if: :outage_id_changed?

  private

  def check_if_exists
    Relationship.where(child_id: self.child_id).update_all(outage_id: self.outage_id)
  end
end

我现在面临的问题是,无论发生什么,UPDATE总是发生在INSERT之前。只有当记录存在并且更改了UPDATE时,才会发生outage_id

任何关于我在这里做错了什么的洞察力都将不胜感激。

EN

回答 1

Stack Overflow用户

发布于 2017-12-05 18:35:52

你可以试试这个,

代码语言:javascript
复制
class Relationship < ApplicationRecord
    before_update :check_if_exists, if: :outage_id_changed?

    private
    def check_if_exists
       # Your logic
    end
end

注意:您的代码check_if_exists中的也将在create上运行,因为在创建过程中outage_id正在从nil更改为<some_id>

但是,使用before_update将确保它只在更新时运行。

还请注意,您使用的是update_all,它会产生一个直接的db查询,并且不会被包装在事务中。这意味着,如果更新失败,通过update_all所做的更改将不会回滚。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47656245

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档