在MySQL中,CEILING()和FLOOR()函数与ROUND()函数有何不同?
CEILING() 函数返回不小于X的最小整数。请考虑以下示例:
mysql> Select CEILING(3.46); +---------------+ | CEILING(3.46) | +---------------+ | 4 | +---------------+ 1 row in set (0.00 sec) mysql> Select CEILING(-6.43); +----------------+ | CEILING(-6.43) | +----------------+ | -6 | +----------------+ 1 row in set (0.02 sec)
FLOOR() 函数返回不大于X的最大整数。请考虑以下示例:
mysql> Select FLOOR(-6.43); +--------------+ | FLOOR(-6.43) | +--------------+ | -7 | +--------------+ 1 row in set (0.00 sec) mysql> Select FLOOR(3.46); +-------------+ | FLOOR(3.46) | +-------------+ | 3 | +-------------+ 1 row in set (0.00 sec)
ROUND() 函数返回四舍五入到最接近整数的X。如果提供第二个参数D,则该函数返回四舍五入到D位小数的X。D必须为正数,否则小数点右边的所有数字都将被删除。请考虑以下示例:
mysql>SELECT ROUND(5.693893); +---------------------------------------------------------+ | ROUND(5.693893) | +---------------------------------------------------------+ | 6 | +---------------------------------------------------------+ 1 row in set (0.00 sec) mysql>SELECT ROUND(5.693893,2); +---------------------------------------------------------+ | ROUND(5.693893,2) | +---------------------------------------------------------+ | 5.69 | +---------------------------------------------------------+ 1 row in set (0.00 sec)
从以上定义和示例中,我们可以观察到这三个函数之间的以下区别:
- ROUND() 函数向上或向下舍入数字取决于第二个参数D和数字本身(D位小数后的数字>=5或不是)。
- FLOOR() 函数始终向下舍入数字(朝零的方向)。
- CEILING() 函数始终向上舍入数字(远离零的方向)。
mysql> Select ROUND(1.415,2),FLOOR(1.415),CEILING(1.415); +----------------+--------------+----------------+ | ROUND(1.415,2) | FLOOR(1.415) | CEILING(1.415) | +----------------+--------------+----------------+ | 1.42 | 1 | 2 | +----------------+--------------+----------------+ 1 row in set (0.00 sec)
广告