ruby-on-rails-3.2 – 使用Ruby on Rails 3.2.14 / Ruby 2.0.0 / PostgreSQL 9.2.4中的activerecord从序列中检索nextval

发布时间:2020-01-14 发布网站:脚本之家
脚本之家收集整理的这篇文章主要介绍了ruby-on-rails-3.2 – 使用Ruby on Rails 3.2.14 / Ruby 2.0.0 / PostgreSQL 9.2.4中的activerecord从序列中检索nextval脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
这应该很简单.我想检索序列的nextval …它不是默认值…它不是主键…它不是外键.在极少数情况下,我需要一个用户提供的值的序列号.

我尝试过以下方法:

@nextid = ActiveRecord::Base.connection.execute("SELECT nextval('xscrpt_id_seq')")

我得到的是:

#<PG::Result:0x007fe668a854e8 @connection=#<PG::Connection:0x00000003aeff30>>

并通过使用

@nextid[0]["nextval"]

我可以得到正确的值,但它似乎不是解决问题的正确方法.我搜索过,我读了“Pro Active Record”,据说使用:

M_script.find_by_sql("SELECT nextval('xscript_id_seq')")

但是,那没用.

任何关于“正确”(Rails方式)的提示,以从ROR中的序列中检索nextval,将非常感激!

解决方法

您可能想要使用select_value和sequence_name:
Xscrpt.connection.select_value("select nextval('#{Xscrpt.sequence_name}')").to_i

总结

以上是脚本之家为你收集整理的ruby-on-rails-3.2 – 使用Ruby on Rails 3.2.14 / Ruby 2.0.0 / PostgreSQL 9.2.4中的activerecord从序列中检索nextval全部内容,希望文章能够帮你解决ruby-on-rails-3.2 – 使用Ruby on Rails 3.2.14 / Ruby 2.0.0 / PostgreSQL 9.2.4中的activerecord从序列中检索nextval所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢交流学习经验,点击链接加入脚本之家官方QQ群:1065694478
脚本之家官方公众号

微信公众号搜索 “ 程序精选 ” ,选择关注!

微信公众号搜索 “ 程序精选 ”
精选程序员所需精品干货内容!