diff options
author | unknown <gluh@mysql.com> | 2005-05-09 16:22:49 +0000 |
---|---|---|
committer | unknown <gluh@mysql.com> | 2005-05-09 16:22:49 +0000 |
commit | c6819bc64c9cb09615d16810c1fe5ddcf10bf962 (patch) | |
tree | a45c1df968541c9eb9aad9f95af0f3d89804be1c /heap | |
parent | fff3214a881ceb63799bff82a21b0ae7e75781a7 (diff) | |
download | mariadb-git-c6819bc64c9cb09615d16810c1fe5ddcf10bf962.tar.gz |
Fix for bug #9404: information_schema: Weird error messages with SELECT SUM() ... GROUP BY queries
heap/hp_hash.c:
Fix for bug #9404: information_schema: Weird error messages with SELECT SUM() ... GROUP BY queries
use length in symbols instead of length in bytes
to calculate record length and key length
Diffstat (limited to 'heap')
-rw-r--r-- | heap/hp_hash.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/heap/hp_hash.c b/heap/hp_hash.c index 52a250bd7af..7f02eb587a8 100644 --- a/heap/hp_hash.c +++ b/heap/hp_hash.c @@ -635,13 +635,12 @@ int hp_key_cmp(HP_KEYDEF *keydef, const byte *rec, const byte *key) key+= 2; /* skip key pack length */ if (cs->mbmaxlen > 1) { - uint char_length= seg->length / cs->mbmaxlen; - char_length_key= my_charpos(cs, key, key + char_length_key, - char_length); - set_if_smaller(char_length_key, seg->length); - char_length_rec= my_charpos(cs, pos, pos + char_length_rec, - char_length); - set_if_smaller(char_length_rec, seg->length); + uint char_length1, char_length2; + char_length1= char_length2= seg->length / cs->mbmaxlen; + char_length1= my_charpos(cs, key, key + char_length_key, char_length1); + set_if_smaller(char_length_key, char_length1); + char_length2= my_charpos(cs, pos, pos + char_length_rec, char_length2); + set_if_smaller(char_length_rec, char_length2); } if (cs->coll->strnncollsp(seg->charset, |