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

阅读量: 349
发布于:
修改于: