diff options
author | gluh@eagle.intranet.mysql.r18.ru <> | 2006-03-06 12:52:38 +0400 |
---|---|---|
committer | gluh@eagle.intranet.mysql.r18.ru <> | 2006-03-06 12:52:38 +0400 |
commit | 33e7d20f370d3bd6905c10b47c0acd23dec79e4a (patch) | |
tree | e545f4c60e224f87066d458e1d421202f502ac32 /sql/item_strfunc.h | |
parent | 519ea6a2780fac66d18f98783d4b5ccb29cc5bd9 (diff) | |
download | mariadb-git-33e7d20f370d3bd6905c10b47c0acd23dec79e4a.tar.gz |
Fix for bug#16678 FORMAT gives wrong result if client run with default-character-set=utf8
calculate Item_func_format::max_length using charset->mbmaxlen
Diffstat (limited to 'sql/item_strfunc.h')
-rw-r--r-- | sql/item_strfunc.h | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/sql/item_strfunc.h b/sql/item_strfunc.h index 50ec0b36ce8..6a95a9e5d1f 100644 --- a/sql/item_strfunc.h +++ b/sql/item_strfunc.h @@ -471,7 +471,9 @@ public: void fix_length_and_dec() { collation.set(default_charset()); - max_length=args[0]->max_length+(args[0]->max_length-args[0]->decimals)/3; + uint char_length= args[0]->max_length/args[0]->collation.collation->mbmaxlen; + max_length= ((char_length + (char_length-args[0]->decimals)/3) * + collation.collation->mbmaxlen); } const char *func_name() const { return "format"; } void print(String *); |