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