Ответ 1
Вы можете использовать
ActiveRecord::Base.connection.open_transactions
чтобы узнать, выполняется ли ваш метод в транзакции.
ActiveRecord::Base.connection.open_transactions == 0
подразумевает, что ваш метод не выполняется в транзакции. Все, что больше 0, означает, что ваш метод выполняется в транзакции. Например, ActiveRecord::Base.connection.open_transactions > 0
Update:
из документации по рельсам
all database statements in the nested transaction block become part of the parent transaction
Таким образом, количество открытых транзакций будет равно, даже если вы находитесь в вложенной транзакции.
Это то, что я получил в своей консоли
ActiveRecord::Base.transaction do
User.first.update_attribute(:first_name, "something")
ActiveRecord::Base.transaction do
User.first.update_attribute(:last_name, "something")
p ActiveRecord::Base.connection.open_transactions
end
end
(0.3ms) BEGIN
User Load (0.8ms) SELECT "users".* FROM "users" LIMIT 1
(0.8ms) UPDATE "users" SET "first_name" = 'something', "updated_at" = '2013-11-20 18:33:52.254088' WHERE "users"."id" = 1
User Load (0.5ms) SELECT "users".* FROM "users" LIMIT 1
(0.4ms) UPDATE "users" SET "last_name" = 'something', "updated_at" = '2013-11-20 18:33:52.266976' WHERE "users"."id" = 1
1
(14.2ms) COMMIT
=> 1