Rails Set one field value from other filed
我需要在某些模型中进行一些批量更新,并将字段的值设置为另一个字段的值.
现在我可以用这样的原始sql做到这一点:
ActiveRecord::Base.connection.execute("UPDATE `funs` SET `funs`.`original_id` = `funs`.`id` WHERE `funs`.`original_id` is NULL")
这工作正常,但由于许多原因我需要使用ActiveRecord查询接口.我试过了:
Fun.where(original_id: nil).update_all(original_id: value_of_id_column)
对于value_of_id_column,我试过:id,self.id id等,没有任何作用.我应该为value_of_id_column设置什么来获取rails生成的原始查询?这是可能的,还是使用原始sql是唯一的解决方案?
此外,我不想迭代每个记录并更新.这对我来说不是一个合适的解决方案:
Fun.where(original_id: nil).each do |deleted_content| update_each_record end
使用下面方面可以实现: Fun.where(created_at: nil).update_all("created_at = updated_at") > Fun Update All (67.6ms) UPDATE "funs" SET created_at = updated_at WHERE "funs"."created_at" IS NULL
阅读量: 814
发布于:
修改于:
发布于:
修改于: