草庐IT

自增主键

全部标签

ruby-on-rails - 在 Rails 4 迁移中设置自定义主键时出现问题

我使用postgresql9.3、Ruby2.0、Rails4.0.0。在阅读了很多有关在表上设置主键的问题后,我生成并添加了以下迁移:classCreateShareholders我还在我的模型中添加了self.primary_key="uid"。迁移成功运行,但是当我使用pgAdminIII连接到数据库时,我看到uid列未设置为主键。我错过了什么? 最佳答案 看看thisanswer.尝试执行“ALTERTABLEshareholdersADDPRIMARYKEY(uid);”,而不在create_tableblock中指定pr

ruby-on-rails - routes.rb,如何为路径设置不同的主键?

给定像Thread(id,uuid)这样的模型,uuid是一个唯一生成的标识符。我想更改默认路由:edit_threadGET/threads/:id/edit(.:format){:action=>"edit",:controller=>"threads"}threadGET/threads/:id(.:format){:action=>"show",:controller=>"threads"}PUT/threads/:id(.:format){:action=>"update",:controller=>"threads"}不使用:id而是使用用户:uuid---这在Rails/

ruby-on-rails - 如何在 Rails 中实现复合主键

我有一个如下所示的User模型:classUser数据库中的users表有两个外键organization_id和department_id。如何使这两列成为复合主键?到目前为止,我在网上看到了两种方法:选项1使用composite_primary_keysgem选项2使用如下方式为两列中的每一列添加索引:add_index:users,[:organization_id,:department_id],unique:true我的问题在users表中唯一标识一行的最佳方法是什么,其中一行必须按顺序具有department_id和organization_id被唯一识别?索引两列和简单地

ruby - 是否可以使用事件记录为表定义复合主键?

这个问题在这里已经有了答案:HowtosetcompositekeyinRailsapplication(2个答案)关闭8年前。我在没有Rails的ruby​​项目中使用ActiveRecord。我需要为表定义复合主键。通常迁移会自动创建主键。是否可以使用事件记录为表定义我自己的复合主键?

ruby-on-rails - 没有主键的 ActiveRecord 模型

我有一个没有主键的ActiveRecord模型GPA:classGPA当我尝试调用GPA.first.to_json时,我得到了TypeError:falseisnotasymbol。我猜这是由于ActiveRecord试图查找主键。在没有主键的情况下实现模型的正确方法是什么? 最佳答案 通常有一些列或列的组合共同构成一个主键。当您说您的表没有主键时,您的意思是它没有id字段吗?是否有另一列是唯一/自然键?如果是这样,您可以这样做:classGPA您还可以将复合键与compositekeysgem结合使用,如下:classGPA

ruby-on-rails - 如何将主键添加到rails中的表

您好,我的Rails应用程序中有一个表,它没有任何ID列或主键。那是因为这张表是从以前的应用程序带入我的Rails应用程序的,并且该表已预先填充了数据。我现在意识到,如果没有整数主键,rails将无法在浏览器中显示编辑和显示View。所以我需要在我的数据库中添加一个id列,这是一个主键和自动增量。根据我的谷歌搜索,我发现了一些关于为表创建主键的帖子,但没有一个是完整的。所以我想知道是否有人可以帮我一下。到目前为止,我所知道的是为了更改表,必须编写一个迁移然后运行它。添加id列需要执行的命令如下:railsgeneratemigrationadd_id_to_businessesid:p

ruby-on-rails - 将 Rails 中的主键更改为字符串

所以我有两个模型,State和Acquisition。状态has_many收购。我觉得51条记录的自动递增整数主键相当愚蠢。所以我将州的模型更改为PK(州是两个字母的缩写;我没有在任何地方存储实际的州名称:classState问题是当我创建采集模型时,它将外键列state_id创建为一个整数。更具体地说,脚本/生成的迁移做了:classCreateAcquisitions我假设t.references数据类型将其设置为int。问题是我的Acquisition类上的创建方法试图将状态缩写放入表acquisitions的state_id字段中(是的,它在数据库上称为state_id,即使它

ruby-on-rails - UUID 作为 PostgreSQL 中的主键是否会带来糟糕的索引性能?

我使用PostgreSQL数据库在Heroku上的Rails中创建了一个应用程序。它有几个表,旨在能够与移动设备同步,在这些设备上可以在不同的地方创建数据。因此,我有一个uuid字段,它是一个存储GUID以及自动递增主键的字符串。uuid是在服务器和客户端之间通信的。我在服务器端实现同步引擎后意识到,当需要一直在uuidid之间映射时,这会导致性能问题(在编写对象时,我需要先查询uuid以获取id保存和发回数据时相反)。我现在正在考虑切换到仅使用UUID作为主键,从而使写入和读取变得更加简单和快速。我读到UUID作为主键有时会在使用聚簇主键索引时导致糟糕的索引性能(索引碎片)。Post

javascript - Ember 数据将模型的主键从 id 更改为其他内容

目前我有这样的模型设置App.Specialty=DS.Model.extend({//specialty_id:attr(),name:attr()});它有一个从名为specialty_id而不是id的jsonapi返回的主键(ember数据可能期望的)。因此,不要摆弄任何东西,ember数据会得到两个对象,其中一个使用id作为任何参数,第二个它得到正确的对象但id未定义。如何让ember数据知道它应该搜索specialty_id? 最佳答案 对于整个应用App.ApplicationSerializer=DS.RESTSeri

javascript - 自增运算符返回 NaN

我正在尝试使用++运算符递增一个变量,但我一直得到NaN结果,我不确定为什么。这是我的代码:varwordCounts={};varx=0varcompare="grooveisintheheart";varwords=compare.split(/\b/);for(vari=1;i2){wordCounts["_"+words[i]]++;}}alert(wordCounts.toSource()); 最佳答案 wordCounts["_"+words[i]]的值最初是undefined所以当你++它时,它给你NaN。只需将您的代