Commit 39c899f3 authored by Zardosht Kasheff's avatar Zardosht Kasheff Committed by Yoni Fogel

addresses #1158

fix cmp_ref

git-svn-id: file:///svn/mysql/tokudb-engine/src@6187 c7de825b-a66e-492c-adef-691d508d4ae1
parent 687aea89
...@@ -2161,15 +2161,19 @@ ha_rows ha_tokudb::estimate_rows_upper_bound() { ...@@ -2161,15 +2161,19 @@ ha_rows ha_tokudb::estimate_rows_upper_bound() {
} }
int ha_tokudb::cmp_ref(const uchar * ref1, const uchar * ref2) { int ha_tokudb::cmp_ref(const uchar * ref1, const uchar * ref2) {
if (hidden_primary_key) if (hidden_primary_key) {
return memcmp(ref1, ref2, TOKUDB_HIDDEN_PRIMARY_KEY_LENGTH); return memcmp(ref1, ref2, TOKUDB_HIDDEN_PRIMARY_KEY_LENGTH);
}
int result; int result;
Field *field; Field *field;
KEY *key_info = table->key_info + table_share->primary_key; KEY *key_info = table->key_info + table_share->primary_key;
KEY_PART_INFO *key_part = key_info->key_part; KEY_PART_INFO *key_part = key_info->key_part;
KEY_PART_INFO *end = key_part + key_info->key_parts; KEY_PART_INFO *end = key_part + key_info->key_parts;
//
// HACK until we get refactoring in. manually move up by infinity byte
//
ref1++;
ref2++;
for (; key_part != end; key_part++) { for (; key_part != end; key_part++) {
field = key_part->field; field = key_part->field;
result = field->pack_cmp((const uchar *) ref1, (const uchar *) ref2, key_part->length, 0); result = field->pack_cmp((const uchar *) ref1, (const uchar *) ref2, key_part->length, 0);
...@@ -3385,8 +3389,9 @@ DBT *ha_tokudb::get_pos(DBT * to, uchar * pos) { ...@@ -3385,8 +3389,9 @@ DBT *ha_tokudb::get_pos(DBT * to, uchar * pos) {
KEY_PART_INFO *key_part = table->key_info[primary_key].key_part; KEY_PART_INFO *key_part = table->key_info[primary_key].key_part;
KEY_PART_INFO *end = key_part + table->key_info[primary_key].key_parts; KEY_PART_INFO *end = key_part + table->key_info[primary_key].key_parts;
for (; key_part != end; key_part++) for (; key_part != end; key_part++) {
pos += key_part->field->packed_col_length(pos, key_part->length); pos += key_part->field->packed_col_length(pos, key_part->length);
}
to->size = (uint) (pos - (uchar *) to->data); to->size = (uint) (pos - (uchar *) to->data);
} }
DBUG_DUMP("key", (const uchar *) to->data, to->size); DBUG_DUMP("key", (const uchar *) to->data, to->size);
...@@ -3544,9 +3549,10 @@ void ha_tokudb::position(const uchar * record) { ...@@ -3544,9 +3549,10 @@ void ha_tokudb::position(const uchar * record) {
else { else {
bool has_null; bool has_null;
create_dbt_key_from_table(&key, primary_key, ref, record, &has_null); create_dbt_key_from_table(&key, primary_key, ref, record, &has_null);
if (key.size < ref_length) if (key.size < ref_length) {
bzero(ref + key.size, ref_length - key.size); bzero(ref + key.size, ref_length - key.size);
} }
}
DBUG_VOID_RETURN; DBUG_VOID_RETURN;
} }
......
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