mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
clearing statement from cache on exception in order to support older versions of mysql
This commit is contained in:
@@ -413,9 +413,19 @@ module ActiveRecord
|
||||
stmt = cache[:stmt]
|
||||
end
|
||||
|
||||
stmt.execute(*binds.map { |col, val|
|
||||
type_cast(val, col)
|
||||
})
|
||||
|
||||
begin
|
||||
stmt.execute(*binds.map { |col, val| type_cast(val, col) })
|
||||
rescue Mysql::Error => e
|
||||
# Older versions of MySQL leave the prepared statement in a bad
|
||||
# place when an error occurs. To support older mysql versions, we
|
||||
# need to close the statement and delete the statement from the
|
||||
# cache.
|
||||
stmt.close
|
||||
@statements.delete sql
|
||||
raise e
|
||||
end
|
||||
|
||||
if metadata = stmt.result_metadata
|
||||
cols = cache[:cols] ||= metadata.fetch_fields.map { |field|
|
||||
field.name
|
||||
|
||||
Reference in New Issue
Block a user