我有一个消息体系结构,消息本身嵌套在一个级别 . 每条消息(父)都可以有多个子节点,每条消息(子节点)都属于父节点 .
parent_id
属性标识消息是父/子,还是其子节点 .
请在下面找到我的模型和相应的关联 .
Class AbstractMessage
belongs_to :parent, class_name: 'AbstractMessage', inverse_of: :children
scope :with_a_parent, where("parent_id IS NOT NULL")
has_many :children, class_name: 'AbstractMessage', foreign_key: :parent_id,
include: [:children],
conditions: "id IN (#{AbstractMessage.with_a_parent.select(:id).to_sql})",
inverse_of: :parent
end
在这种情况下,我面临着一个带有以下查询的无限递归循环 .
AbstractMessage.where(id: message_root_ids).includes(:children).index_by(&:id)
奇怪的是 this issue happens only when it is being called via web server (passenger/nginx)
. 从控制台触发时相同的查询返回正确的结果 .
有关此问题发生原因的任何帮助 . 也是为什么它只通过Web服务器发生 .
在此先感谢您的帮助 .