我正在使用Rails 2,我在此应用中的Project
模型和Schedule
模型之间存在一对多的关联。
我有一个观察者检查各种事物的属性是否发生变化,作为回应,它会迭代一组哈希值,用以填充新的Schedule
个实例。
每个Schedule
实例都应该有一个属性disp_order
,最终告诉前端在列表中显示它们时显示它的位置。在将计划添加到项目时填充disp_order
,使其等于当前最高disp_order
的一个。
问题在于观察者的迭代。当我遍历填充了Schedule
数据的哈希数组时,每次迭代都应该将disp_order
计算为比前一个更高的一个,以考虑它刚刚添加的Schedule
。但是,在实践中,它不会 - 除非我使用Project
在迭代过程中刷新project = Project.find(project.id)
对象,否则似乎总是计算{{1}的相同最大值s,并且没有准确的disp_order
个实例列表。
有更好的方法吗? (注意:我只是说有更好的方法,所以我不必告诉项目重新找到自己。有很多地方我正在积极清理后面的其余代码,但为此问题我真的只对这一行和影响它的事情感兴趣。)
Schedule
class Project < ActiveRecord::Base
# ...
has_many :schedules, :dependent => :destroy
# ...
belongs_to :data, :polymorphic => true, :dependent => :destroy
accepts_nested_attributes_for :data
# ...
class Schedule < ActiveRecord::Base
belongs_to :project, :include => [:data]
# ...
class ProjectEventObserver < ActiveRecord::Observer
# ...
def perform_actions(project, actions)
# ...
actions.each { |action|
action.each { |a_type, action_list|
action_list.each { |action_data|
self.send(action_type.to_s.singularize, action_data, project)
project = Project.find(project.id) #My question is about this line.
}
}
}
# ...
[
{:add_tasks => [
{:name => "Do a thing", :section => "General"},
{:name => "Do another thing", :section => "General"},
]
},
# More like this one.
]
def add_task(hash, project)
# ...
sched = Schedule.new
hash.each { |key, val|
# ...
sched.write_attribute(key, val)
# ...
}
sched.add_to(project)
end
答案 0 :(得分:3)
您正在遇到此问题,因为您正在处理内存中的缓存对象。
您可以在Schedule模型的add_to函数中传递true参数来重新加载查询。
其他选项包括inverse_of,但是您无法使用这些选项,因为您根据文档使用了多态关联。