ruby-on-rails – 如何找出为什么我不能#destroy()一个记录?

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 如何找出为什么我不能#destroy()一个记录?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
person = Person.find(4123)
person.destroy #=> false

找出为什么不删除记录的方法是什么?该模型有两个验证,仅在创建时触发.它有一个回调,但回调不会阻止,如果它失败.

我没有追溯或错误看.

解决方法

我碰到了同样的问题,这里是我做了什么来弄清楚发生了什么事情

首先,对于我想要销毁的对象的类,我运行这个来确定所有关联被设置为依赖关系::destroy:

ary = Klass.reflect_on_all_associations
           .select { |a| a.options[:dependent] == :destroy }
           .map(&:name)

然后我打电话给我的对象中的每个ary命名的关联并收集结果.这将关联名称限制为仅具有依赖对象的关联名称

ary.select! { |a| obj.send(a).any? }

然后我可以尝试销毁这些关联名称返回的每个对象:

destroy_me = obj.send(ary[0]).first
destroy_me.destroy

我只有一个对象,所以以上是足以导致破坏失败.然后我可以看看对象上的错误是不能销毁的:

destroy_me.errors

这就是我终于看到导致销毁失败的错误.从那里,它是一个简单的编程(SMOP)来解决这个问题.

在我的情况下,有一个before_destroy回调,防止破坏在我的一个依赖对象关联中工作.为了使以后更简单的调试,我决定开始将错误记录到Rails登录失败的回调(除了将错误消息添加到errors.base之外).

猜你在找的Ruby相关文章