首页 > 解决方案 > Acitverecord 用 `through` 指定 `inverse_of` 但不是相反

问题描述

我有3个模型如下:

class User
  has_many :event_series, inverse_of: :user
  has_many :events, through: :event_series, inverse_of: :user
end

class EventSeries
  belongs_to :user, inverse_of: :event_series
  has_many :events, inverse_of: :event_series
end

class Event
  belongs_to :event_series, inverse_of: :events
  has_one :user, through: :event_series, inverse_of: :events
end

这一切都很好。现在我想为每个用户添加一个名为“showcase_event”的特殊事件。

class User
  has_one :showcase_event, class_name: 'Event', inverse_of: :user
end

这不起作用,因为Event模型没有直接拥有用户,它通过EventSeries.

我在序列化过程中遇到错误:

ActiveRecord::StatementInvalid (PG::UndefinedColumn: ERROR:  column events.user_id does not exist

我正在使用快速 jsonapi:

class PublicUserSerializer
  include FastJsonapi::ObjectSerializer
  ...
  has_one :showcase_event, record_type: :event, serializer: EventSerializer
  ...
end

在我看来,我之间的反向关系User需要在EventEventSeries之间起作用Usershowcase_event但我不知道如何指定只有反向是通过EventSeries 事先道歉,因为没有最好的词汇来描述这个问题。

标签: ruby-on-railsrubyactiverecordassociationsrails-activerecord

解决方案


由我的橡皮鸭解决。如文档中所示:

#belongs_to关联总是在具有外键的模型中使用。

所以我将我的声明更改showcase_event为:

class User
  belongs_to :showcase_event, class_name: 'Event', inverse_of: :user, optional: true
end

并且问题解决了


推荐阅读