Commit 83e0c3a6 authored by Nikita Malyavin's avatar Nikita Malyavin

compare refs instead of whole rows (fixme: innodb case fails)

parent 96b8697d
...@@ -6984,6 +6984,10 @@ int handler::ha_check_overlaps(const uchar *old_data, const uchar* new_data) ...@@ -6984,6 +6984,10 @@ int handler::ha_check_overlaps(const uchar *old_data, const uchar* new_data)
return error; return error;
} }
handler= check_overlaps_handler; handler= check_overlaps_handler;
// Needs to compare record refs later is old_row_found()
if (is_update)
position(old_data);
} }
// Save and later restore this handler's keyread // Save and later restore this handler's keyread
...@@ -7013,13 +7017,21 @@ int handler::ha_check_overlaps(const uchar *old_data, const uchar* new_data) ...@@ -7013,13 +7017,21 @@ int handler::ha_check_overlaps(const uchar *old_data, const uchar* new_data)
if (error) if (error)
return error; return error;
auto old_row_found= [is_update, old_data, record_buffer, this](){ auto old_row_found= [is_update, old_data, record_buffer, this, handler](){
if (!is_update)
return false;
/* In case of update it could appear that the nearest neighbour is /* In case of update it could appear that the nearest neighbour is
* a record we are updating. It means, that there are no overlaps * a record we are updating. It means, that there are no overlaps
* from this side. */ * from this side.
return is_update && memcmp(old_data + table->s->null_bytes, *
record_buffer + table->s->null_bytes, * An assumption is made that during update we always have the last
table->s->reclength - table->s->null_bytes) == 0; * fetched row in old_data. Therefore, comparing ref's is enough
* */
DBUG_ASSERT(handler != this && inited != NONE);
DBUG_ASSERT(ref_length == handler->ref_length);
handler->position(record_buffer);
return memcmp(ref, handler->ref, ref_length) == 0;
}; };
error= handler->ha_start_keyread(key_nr); error= handler->ha_start_keyread(key_nr);
......
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