Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

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)

위의 정의와 예에서 우리는 이 세 가지 기능 간의 다음 차이점을 관찰할 수 있습니다.

  • 라운드() 숫자를 반올림하거나 내림하는 함수는 두 번째 인수 D와 숫자 자체(D 소수점 이하 자릿수>=5 여부)에 따라 달라집니다.
  • FLOOR() 함수는 숫자를 0을 향해 반올림하고 항상 내립니다.
  • 천장() 함수는 숫자를 0에서 멀리 반올림하여 항상 위로 올립니다.
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)