我写了这个任务来填充一个表。“飞行”表非常大(23000 个帖子)。但是当我们第二次通过循环时,我得到了这个奇怪的错误。
这是代码:
desc "Compute the AirlineTerminal Table"
task :populate_airlineterminals => :environment do
#first delete content
AirlineTerminal.destroy_all
allFlights = Flight.all
#AFTER ONE ITERATION THE ERROR HAPPENS
allFlights.each do |f|
atTerminal = AirlineTerminal.where(:airline_id => f.airline_id, :airport_id => f.airport_id, :terminal => f.terminal).first
if atTerminal.nil?
atTerminal = AirlineTerminal.new
atTerminal.airport_id = f.airport_id
atTerminal.airline_id = f.airline_id
atTerminal.terminal = f.terminal
end
atTerminal.count++
atTerminal.save #so far so good
end
end
这就是我运行脚本时发生的情况,经过一次循环后它会崩溃。
$ rake populate_airlineterminals
rake aborted!
undefined method `+@' for true:TrueClass