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

ruby-on-rails-3.2 – 使用Ruby on Rails 3.2.14 / Ruby 2.0.0 /

发布时间:2020-12-17 04:32:25 所属栏目:百科 来源:网络整理
导读:这应该很简单.我想检索序列的nextval …它不是默认值…它不是主键…它不是外键.在极少数情况下,我需要一个用户提供的值的序列号. 我尝试过以下方法: @nextid = ActiveRecord::Base.connection.execute("SELECT nextval('xscrpt_id_seq')") 我得到的是: #PG
这应该很简单.我想检索序列的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

(编辑:李大同)

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

    推荐文章
      热点阅读