summaryrefslogtreecommitdiff
path: root/sql/item_buff.cc
diff options
context:
space:
mode:
authorevgen@moonbone.local <>2006-10-11 19:44:12 +0400
committerevgen@moonbone.local <>2006-10-11 19:44:12 +0400
commitea8a646dc0fcf2cd36475e932f29348ce04dc120 (patch)
tree667f42f01a14de899bbf9ac1ddaf182fd644b46d /sql/item_buff.cc
parent5367793e8bca95143acfe13aa84cbec24e4b29d9 (diff)
downloadmariadb-git-ea8a646dc0fcf2cd36475e932f29348ce04dc120.tar.gz
Bug#22138: Unhandled NULL caused server crash
The Cached_item_decimal::cmp() method wasn't checking for null pointer returned from the val_decimal() of the item being cached. This leads to server crash. The Cached_item_decimal::cmp() method now check for null values.
Diffstat (limited to 'sql/item_buff.cc')
-rw-r--r--sql/item_buff.cc12
1 files changed, 9 insertions, 3 deletions
diff --git a/sql/item_buff.cc b/sql/item_buff.cc
index 1661f04a4ae..37f9ca7ce6c 100644
--- a/sql/item_buff.cc
+++ b/sql/item_buff.cc
@@ -132,11 +132,17 @@ bool Cached_item_decimal::cmp()
{
my_decimal tmp;
my_decimal *ptmp= item->val_decimal(&tmp);
- if (null_value != item->null_value || my_decimal_cmp(&value, ptmp))
+ if (null_value != item->null_value ||
+ (!item->null_value && my_decimal_cmp(&value, ptmp)))
{
null_value= item->null_value;
- my_decimal2decimal(ptmp, &value);
- return TRUE;
+ /* Save only not null values */
+ if (!null_value)
+ {
+ my_decimal2decimal(ptmp, &value);
+ return TRUE;
+ }
+ return FALSE;
}
return FALSE;
}