繁体   English   中英

Rails将delete_if转换为sql语句

[英]Rails convert delete_if to sql statement

我使用delete_if编写了一个异常,遇到了问题,想使用SQL语句或使用活动记录的东西。

这是我的delete_if语句:

Format.all.delete_if { |f| ( f.location_ids.sort & User.current.location_ids.sort ) == User.current.location_ids.sort }

基本上,该语句为如果所有用户location_ids都包含在location_ids格式中,则删除。

我不完全理解您的问题,但是也许这段代码正是您要寻找的:

current_user_location_ids = User.current.location_ids.sort

formats_to_destroy = Format.all.to_a.select do |format|
  format.location_ids.sort == current_user_location_ids
end

formats_to_destroy.map(&:destroy)

注意:它实际上会破坏数据库中的记录!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM