【问题标题】:How to fix invalid references after a delete_all如何在 delete_all 后修复无效引用
【发布时间】:2020-11-09 21:25:36
【问题描述】:

我有以下关系:

class Blog
  belongs_to :owner
end

class Owner
  has_one :blog, dependent: :destroy
end

错误地,我没有使用destroy_all,而是使用了delete_all。现在我在数据库中有一堆无效的引用。如何解决这个问题?

【问题讨论】:

  • 所以您现在只是在寻找没有所有者 ID 的博客?还是不存在的所有者 ID?
  • 您应该在数据库中添加外键约束,以防止此类事情再次发生。

标签: mysql ruby-on-rails


【解决方案1】:

rails dbconsole 运行以下查询:

delete from blogs where owner_id not in (select id from owners);

【讨论】:

  • 那是mysql吗??
  • 是的。也应该适用于 postgtes 和许多其他数据库。
猜你喜欢
  • 1970-01-01
  • 2012-05-02
  • 2020-09-22
  • 2020-09-13
  • 1970-01-01
  • 2018-02-25
  • 1970-01-01
  • 1970-01-01
  • 2019-11-15
相关资源
最近更新 更多