在 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 还是不等于 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)
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP