我有一个消息体系结构,消息本身嵌套在一个级别。每条消息(父)都可以有多个子节点,每条消息(子节点)都属于父节点。
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)
。从控制台触发时,相同的查询会返回正确的结果。
有关此问题发生原因的任何帮助。也是为什么它只通过网络服务器发生。
提前感谢您的帮助。