Commit 7e7d98a2 authored by hf@deer.(none)'s avatar hf@deer.(none)

Fix for bug #8430 (CEILING returns incorrect result)

parent 18f13a24
...@@ -1629,13 +1629,25 @@ void Item_func_int_val::find_num_type() ...@@ -1629,13 +1629,25 @@ void Item_func_int_val::find_num_type()
longlong Item_func_ceiling::int_op() longlong Item_func_ceiling::int_op()
{ {
/* longlong result;
the volatile's for BUG #3051 to calm optimizer down (because of gcc's switch (args[0]->result_type()) {
bug) case INT_RESULT:
*/ result= args[0]->val_int();
volatile double value= args[0]->val_real(); null_value= args[0]->null_value;
null_value= args[0]->null_value; break;
return (longlong) ceil(value); case DECIMAL_RESULT:
{
my_decimal dec_buf, *dec;
if ((dec= decimal_op(&dec_buf)))
my_decimal2int(E_DEC_FATAL_ERROR, dec, unsigned_flag, &result);
else
result= 0;
break;
}
default:
result= (longlong)real_op();
};
return result;
} }
......
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