Commit e89ec260 authored by Luis Soares's avatar Luis Soares

BUG#12558519

Automerged bzr bundle from bug report into latest mysql-5.5.
parents b35c4656 96ba6663
...@@ -8441,6 +8441,7 @@ int Table_map_log_event::do_apply_event(Relay_log_info const *rli) ...@@ -8441,6 +8441,7 @@ int Table_map_log_event::do_apply_event(Relay_log_info const *rli)
m_field_metadata, m_field_metadata_size, m_field_metadata, m_field_metadata_size,
m_null_bits, m_flags); m_null_bits, m_flags);
table_list->m_tabledef_valid= TRUE; table_list->m_tabledef_valid= TRUE;
table_list->m_conv_table= NULL;
table_list->open_type= OT_BASE_ONLY; table_list->open_type= OT_BASE_ONLY;
/* /*
......
...@@ -1258,6 +1258,16 @@ void Relay_log_info::clear_tables_to_lock() ...@@ -1258,6 +1258,16 @@ void Relay_log_info::clear_tables_to_lock()
tables_to_lock->m_tabledef.table_def::~table_def(); tables_to_lock->m_tabledef.table_def::~table_def();
tables_to_lock->m_tabledef_valid= FALSE; tables_to_lock->m_tabledef_valid= FALSE;
} }
/*
If blob fields were used during conversion of field values
from the master table into the slave table, then we need to
free the memory used temporarily to store their values before
copying into the slave's table.
*/
if (tables_to_lock->m_conv_table)
free_blobs(tables_to_lock->m_conv_table);
tables_to_lock= tables_to_lock=
static_cast<RPL_TABLE_LIST*>(tables_to_lock->next_global); static_cast<RPL_TABLE_LIST*>(tables_to_lock->next_global);
tables_to_lock_count--; tables_to_lock_count--;
......
...@@ -2189,7 +2189,15 @@ void free_blobs(register TABLE *table) ...@@ -2189,7 +2189,15 @@ void free_blobs(register TABLE *table)
for (ptr= table->s->blob_field, end=ptr + table->s->blob_fields ; for (ptr= table->s->blob_field, end=ptr + table->s->blob_fields ;
ptr != end ; ptr != end ;
ptr++) ptr++)
{
/*
Reduced TABLE objects which are used by row-based replication for
type conversion might have some fields missing. Skip freeing BLOB
buffers for such missing fields.
*/
if (table->field[*ptr])
((Field_blob*) table->field[*ptr])->free(); ((Field_blob*) table->field[*ptr])->free();
}
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment