我有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,Event和EventSeries之间的反向关系需要在User和showcase_event之间工作,但我不知道如何指定只有反向关系才是通过EventSeries提前道歉,因为没有最好的词汇来描述这个问题。
发布于 2019-05-30 00:45:37
由我的橡皮鸭解决。如documentation中所示:
在具有外键的模型中始终使用
#belongs_to关联。
因此,我将showcase_event的声明更改为:
class User
belongs_to :showcase_event, class_name: 'Event', inverse_of: :user, optional: true
end解决了问题
https://stackoverflow.com/questions/56364995
复制相似问题