Kin*_*ark 6 postgresql activerecord ruby-on-rails
如何将表事件中的数据写入json文件?请看这段代码:
在模型event.rb中
class Event < ActiveRecord::Base
attr_accessible :name, :event_description, :start_at, :end_at, :status, :eventable_id
has_event_calendar
belongs_to :eventable, polymorphic: true
after_save :write_json
end
def write_json
Event.all.each do |event|
@eventJson = {
"id" => event.id,
"start" => event.start_at,
"end" => event.end_at,
"title" => event.name,
"body" => event.event_description,
"status" => event.status
}
end
File.open("public/event.json","w") do |f|
f.write(@eventJson.to_json)
end
end
Run Code Online (Sandbox Code Playgroud)
在文件中Json有一条记录,但在表中event有许多记录.event保存记录后,如何将表中的所有记录写入event.json文件?
公共/ event.json
{"id":35,"start":"2013-03-28T00:00:00Z","end":"2013-03-28T00:00:00Z","title":"1345edrewrewr","body":"123124","status":"Confirm"}
Run Code Online (Sandbox Code Playgroud)
Ily*_*kov 13
问题是您@eventJson在循环中分配值,以便先前的值丢失.你应该使用一个数组:
def write_json
events_json = []
Event.all.each do |event|
event_json = {
"id" => event.id,
"start" => event.start_at,
"end" => event.end_at,
"title" => event.name,
"body" => event.event_description,
"status" => event.status
}
events_json << event_json
end
File.open("public/event.json","w") do |f|
f.write(events_json.to_json)
end
end
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10717 次 |
| 最近记录: |