我正在尝试删除一组用户,但我拥有它的方式是逐个删除。有没有更好的方法呢?
我的代码是:
@users ||= User.where("clicks_given - clicks_received < ?", -5).to_a
@users.each do |user|
user.destroy
end
答案 0 :(得分:12)
您可以使用Rails的内置方法。请注意,在使用这些方法时,需要将查询包装在数组中(如果要插入变量)。
迭代每个调用destroy(将运行回调等):
User.destroy_all(["clicks_given - clicks_received < ?", -5])
或者只是在一个查询中删除数据库(不对每个项目进行迭代),你可以这样做,但请记住它不会运行你的回调:
User.delete_all(["clicks_given - clicks_received < ?", -5])
答案 1 :(得分:10)
您可以使用destroy_all
方法:
User.destroy_all("clicks_given - clicks_received < ?", -5)
参考: http://apidock.com/rails/v3.0.5/ActiveRecord/Relation/destroy_all
我之前也使用过以下内容:
@users.map(&:destroy)
它基本上与你的每次通话做同样的事情,但你可以避免使用样板代码。