加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 如何更改Rails中记录的主ID?

发布时间:2020-12-16 20:42:39 所属栏目:百科 来源:网络整理
导读:rails consoleu = User.find(9)u.id = 7 # There is no other record with id 7u.save= trueUser.all ID没有改变. 如何更改主ID?为什么会阻止这个动作? 在Rails 3.0.7和PostgreSQL中工作. 编辑: 既然有很好的理由不这样做,我会解释为什么,希望这是一个很
rails console
u = User.find(9)
u.id = 7 # There is no other record with id 7
u.save
=> true
User.all

ID没有改变.

如何更改主ID?为什么会阻止这个动作?

在Rails 3.0.7和PostgreSQL中工作.

编辑:
既然有很好的理由不这样做,我会解释为什么,希望这是一个很好的理由.

我们正在进行分阶段的可用性测试,所以我希望它看起来像生产,使每个人都容易.我不想在可用性测试过程中产生混乱或错误,通过在“暂存”上按一个顺序执行某些操作,并在“生产”上以不同的顺序.我只更改了Staging DB上的一个PK ID.

不要在你的生产DB上这样做!

解决方法

我不知道为什么它阻止这种行为,但它确实阻止它.

您可以使用update_all方法绕过此用户.

User.update_all("id = 7","id = 9")

尽管如果可能,你真的应该避免这样做.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读