/ / Rails 3 + Transactions: ¿cómo funcionan? - ruby, ruby-on-rails-3, transacciones

Rails 3 + Transactions: ¿cómo funcionan? - ruby, ruby-on-rails-3, transacciones

Tengo este código, como pueden ver, tengo dos parámetros. Y en la una tabla creo nuevos campos, en otra tabla actualicé los campos.

Necesito pegarlos en MySQL. Todo está bien, pero tengo una pregunta: cómo hacer una transacción porque no quiero pegar en la base de datos solo una de ellas (actualizar o crear). Porque ahora, si llené un parámetro, la tabla se crea o actualiza. , pero quiero ponerlos TODOS en la base de datos de la ONCE. Entonces, mi pregunta es ... ¿cómo hacer una transacción para evitar pegar uno de ellos?

json_grid_params = ActiveSupport::JSON.decode(params[:grid_json])
json_form_params = ActiveSupport::JSON.decode(params[:form_json])

json_grid_params.each do |json_grid_params|
report      = Report.find(:all, :conditions => ["wat_id in (?)", json_grid_params["wat_id"].to_i])

report.each do |r|
rr = r.update_attributes(:percent_money => json_grid_params["percent_money"],
:percent_item  => json_grid_params["percent_item"],
:trend         => json_grid_params["trend"])
end

form = FormAnswer.create(json_form_params)

actualizado:

ActiveRecord::Base.transaction do
json_grid_params = ActiveSupport::JSON.decode(params[:grid_json])
json_form_params = ActiveSupport::JSON.decode(params[:form_json])
json_grid_params.each do |json_grid_params|
report = Report.find(:all, :conditions => ["wat_id in (?)", json_grid_params["wat_id"].to_i])
report.each do |r|
rr = r.update_attributes(:percent_money => json_grid_params["percent_money"],
:percent_item  => json_grid_params["percent_item"],
:trend         => json_grid_params["trend"])
rr.save!
form = FormAnswer.create(json_form_params)
#form.save!
end
end
end

y en el registro tienen este error: (Si dejo grid_params vacíos)

NoMethodError (undefined method `save!" for true:TrueClass):
app/components/report_grid.rb:122:in `block (4 levels) in <class:ReportGrid>"
app/components/report_grid.rb:118:in `each"
app/components/report_grid.rb:118:in `block (3 levels) in <class:ReportGrid>"
app/components/report_grid.rb:116:in `each"
app/components/report_grid.rb:116:in `block (2 levels) in <class:ReportGrid>"
app/components/report_grid.rb:113:in `block in <class:ReportGrid>"

Rendered /home/parallels/.rvm/gems/ruby-1.9.3-p0@rails314/gems/actionpack-3.1.4/lib/action_dispatch/middleware/templates/rescues/_trace.erb (0.7ms)
Rendered /home/parallels/.rvm/gems/ruby-1.9.3-p0@rails314/gems/actionpack-3.1.4/lib/action_dispatch/middleware/templates/rescues/_request_and_response.erb (0.8ms)
Rendered /home/parallels/.rvm/gems/ruby-1.9.3-p0@rails314/gems/actionpack-3.1.4/lib/action_dispatch/middleware/templates/rescues/diagnostics.erb within rescues/layout (2.8ms)

Respuestas

0 para la respuesta № 1
ActiveRecord::Base.transaction do
...
end

envolverá el bloque en una transacción. Si algunos de sus modelos tienen conexiones de base de datos diferentes, llame a la transacción en esa clase específica para que la transacción se realice en la conexión correcta.