Commit 146893a7 authored by unknown's avatar unknown
Browse files

Fix for bug #10083 (round doesn't increase scale)


mysql-test/r/func_math.result:
  test result fixed
mysql-test/t/func_math.test:
  test case added
sql/item_func.cc:
  now we always use decimals_to_set
parent 7073dda6
Loading
Loading
Loading
Loading
+3 −0
Original line number Diff line number Diff line
@@ -143,3 +143,6 @@ select format(col2,6) from t1 where col1=7;
format(col2,6)
1,234,567,890,123,456.123450
drop table t1;
select round(150, 2);
round(150, 2)
150.00
+5 −0
Original line number Diff line number Diff line
@@ -79,3 +79,8 @@ insert into t1 values(7,1234567890123456.12345);
select format(col2,6) from t1 where col1=7;
drop table t1;


#
# Bug #10083 (round doesn't increase decimals)
#
select round(150, 2);
+7 −12
Original line number Diff line number Diff line
@@ -1876,7 +1876,8 @@ void Item_func_round::fix_length_and_dec()
    max_length= float_length(decimals);
    break;
  case INT_RESULT:
    if (truncate || (args[0]->decimal_precision() < DECIMAL_LONGLONG_DIGITS))
    if ((decimals_to_set==0) &&
        (truncate || (args[0]->decimal_precision() < DECIMAL_LONGLONG_DIGITS)))
    {
      /* Here we can keep INT_RESULT */
      hybrid_type= INT_RESULT;
@@ -1890,16 +1891,10 @@ void Item_func_round::fix_length_and_dec()
    hybrid_type= DECIMAL_RESULT;
    int decimals_delta= args[0]->decimals - decimals_to_set;
    int precision= args[0]->decimal_precision();
    if (decimals_delta > 0)
    {
      int length_increase= truncate ? 0:1;
    int length_increase= ((decimals_delta <= 0) || truncate) ? 0:1;

    precision-= decimals_delta - length_increase;
    decimals= decimals_to_set;
    }
    else
      /* Decimals to set is bigger that the original scale */
      /* we keep original decimals value                   */
      decimals= args[0]->decimals;
    max_length= my_decimal_precision_to_length(precision, decimals,
                                               unsigned_flag);
    break;