首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails 4 has_one自参考列

Rails 4 has_one自参考列
EN

Stack Overflow用户
提问于 2018-01-19 22:21:31
回答 2查看 961关注 0票数 0

我有图腾模型和图腾表。

将会有许多图腾,我需要将图腾的顺序存储在数据库表中。我在图腾表中添加了一个previous_totem_id和next_totem_id来存储订单信息。我是通过Rails迁移完成的:

代码语言:javascript
复制
class AddPreviousNextTotemColumnsToTotems < ActiveRecord::Migration
  def change
    add_column :totems, :previous_totem_id, :integer
    add_column :totems, :next_totem_id, :integer
  end
end

现在,在模型中,我定义了关系:

代码语言:javascript
复制
class Totem < ActiveRecord::Base
  validates :name, :presence => true

  has_one :previous_totem, :class_name => 'Totem'
  has_one :next_totem, :class_name => 'Totem'
end

我通过ActiveRecord创建了几个图腾,并尝试使用previous_totem_id列如下所示:

代码语言:javascript
复制
totem = Totem.create! name: 'a1'
Totem.create! name: '1a'
totem.previous_totem_id = Totem.find_by(name: '1a').id
puts totem.previous_totem #This is NIL

但是,previous_totem作为零返回,在调用此行时,我没有在mysql日志中看到select语句。

代码语言:javascript
复制
totem.previous_totem

这段关系推荐吗?实现自引用列的最佳方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-01-19 23:46:38

将关联的方向从has_one更改为belongs_to并指定外键,将使代码如您所期望的那样工作:

代码语言:javascript
复制
class Totem < ActiveRecord::Base
  validates :name, :presence => true

  belongs_to :previous_totem, :class_name => 'Totem', foreign_key: :previous_totem_id
  belongs_to :next_totem, :class_name => 'Totem', foreign_key: :next_totem_id
end

但是,良好的关联应该在双方都正确命名和声明--使用匹配的has_one关联;在这种情况下,如果不命名冲突是不可能的:) 自连接有时可能有用,但我不确定它是否是这里的最佳解决方案。我没有使用gem moveson建议,但是使用整数列来存储位置,IMHO使重新排序记录更容易:)

票数 3
EN

Stack Overflow用户

发布于 2018-01-19 22:50:56

如果自我引用的唯一原因是为了存储图腾的顺序,请不要这样做。今天是你的幸运日:这是一个解决的问题!

使用position字段和列表 gem,它将以整洁和高效的方式为您解决这个问题。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48350379

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档