作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个针对 mysql 服务器执行此操作的迁移:
ActiveRecord::Base.connection.execute("update 'comments' set 'slug' = NULL;")
此语句的目的是删除每一行的“slug”值。
该表中有数百万行,使用 ruby 执行类似 Comment.each...
有没有办法重写这个查询,使其与数据库无关,或者至少在 MySQL 和 postgresql 之间工作正常?
谢谢!
最佳答案
Comment.update_all(:slug => nil)
这会生成查询 UPDATE "comments"SET "slug"= NULL
您还可以对范围和条件进行批量更新。例如,您可以:
Comment.where(:some_attribute => "some_value").update_all(:slug => nil)
这会产生 UPDATE "comments"SET "slug"= NULL WHERE (some_attribute = 'some_value')
关于mysql - rails ActiveRecord : Looking for a db agnostic version of this statement,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8364709/
我是一名优秀的程序员,十分优秀!