• MySQL매뉴얼
    • MySQL 5.6 매뉴얼
    • MySQL 5.1 매뉴얼
    • MySQL 5.0 매뉴얼
    • MySQL HA 매뉴얼
  • 기술문서
    • Xtrabackup 구성
    • 메모리 사용량 모니터링
  • 라이선스
  • 온라인문의
  • 회사소개
  • → 목 록 (MySQL5.6 한글메뉴얼) [close]
  • 1. MySQL 5.6 새로운 기능
  • 2. MySQL 설치 및 업그레이드
  • 3. MySQL Tutorial
  • 4. MySQL 프로그램
  • 5. MySQL 서버관리
  • 6. 보안
  • 7. 백업 및 복구
  • 8. 최적화
  • 9. Language Structure(언어구조)
  • 10. Character Sets(Globalization)
  • 11. 데이터형(Data Types)
  • 12. 함수와 연산자
  • 1. 함수와 연산자 참조
    2. 식 평가 형식 변환
    3. 연산자
    4. 제어 흐름 함수
    5. 문자열 함수
    6. 수치 함수와 연산자
    7. 날짜 및 시간 함수
    8. MySQL에서 사용되는 달력
    9. Full-Text 검색 기능
    10. 캐스트 함수와 연산자
    11. XML 함수
    12. 비트 함수
    13. 암호화 함수와 압축 함수
    14. 정보 함수
    15. 공간 분석 함수
    16. 글로벌 트랜잭션 ID와 함께 사용되는 함수
    17. MySQL Enterprise Encryption 기능
    18. 기타 함수
    19. GROUP BY 절에서 사용되는 함수와 수식
    20. 정밀 계산
    1. 숫자 형태
    2. DECIMAL 데이터 유형의 특성
    3. 식의 처리
    4. 둥근 동작
    5. 정밀 계산의 예
  • 13. SQL 문법
  • 14. InnoDB 스토리지 엔진
  • 15. 기타 스토리지 엔진
  • 16. 고가용성 및 확장성
  • 17. 리플리케이션
  • 18. MySQL Cluster
  • 19. 파티셔닝
  • 20. Stored Programs and Views
  • 21. INFORMATION_SCHEMA
  • 22. PERFORMANCE SCHEMA
  • 23. 컨넥터 및 API
  • 24. MySQL 확장
  • 25. MySQL Enterprise Edition
  • 26. MySQL Workbench
  • 27. 제약 및 제한
  • 28. MySQL 5.7 새로운 기능

12.20.4 둥근 동작

이 섹션에서는 ROUND() 함수 및 엄격한 치형 ( DECIMAL 과 정수)을 가지는 컬럼에 삽입하여 정밀 계산의 둥근 대해 설명합니다.

ROUND() 함수는 인수가 정확한 값 또는 근사치인지에 따라 다른 방법으로 반올림합니다.

  • 진정한 값의 수치의 경우 ROUND() 는 "반올림"규칙을 사용합니다. 0.5 이상 소수부를 가진다 값은 양수이면 다음 정수로 반올림, 부의 경우는 다음의 정수로 평가 절하합니다. (즉, 처음부터 먼쪽으로 반올림합니다.) 0.5 미만의 소수 부분을 가지는 값은 양의 경우는 다음의 정수로 평가 절하되고, 부의 경우는 다음 정수로 반올림됩니다.

  • 근사치 숫자의 경우, 결과는 C 라이브러리에 따라 다릅니다. 즉, 대부분의 시스템에서는 ROUND() 는 "짝수 반올림"규칙을 사용합니다. 어떤 소수부를 가진다 값도 가장 가까운 짝수로 반올림됩니다.

다음 예제에서는 정확한 값의 반올림과 근사값의 반올림 차이점을 보여줍니다.

mysql> SELECT ROUND(2.5), ROUND(25E-1);
+------------+--------------+
| ROUND(2.5) | ROUND(25E-1) |
+------------+--------------+
| 3          |            2 |
+------------+--------------+

DECIMAL 또는 정수 컬럼에 삽입에서는 대상이 엄격 값 데이터 형식이기 때문에 삽입되는 값이 정확한 값 또는 근사치의인지에 관계없이 둥근에서는 "반올림"가 사용됩니다.

mysql> CREATE TABLE t (d DECIMAL(10,0));
Query OK, 0 rows affected (0.00 sec)

mysql> INSERT INTO t VALUES(2.5),(2.5E0);
Query OK, 2 rows affected, 2 warnings (0.00 sec)
Records: 2  Duplicates: 0  Warnings: 2

mysql> SELECT d FROM t;
+------+
| d    |
+------+
| 3    |
| 3    |
+------+


서울시 강남구 영동대로 602 6층
TEL: 02-6061-0006  /  E: csr@mysqlkorea.com
주식회사 이노클러스터  등록번호 : 727-86-02261
Copyright © innocluster Co. ltd. all rights reserved