MySQL이 부동 소수점 값을 비교하는 데 어려움을 겪는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-07 19:47:03
원래의
954명이 탐색했습니다.

Why Does MySQL Struggle with Comparing Floating-Point Values?

MySQL의 부동 소수점 값 비교 함정

MySQL의 부동 소수점 계산은 고유한 정밀도 제한으로 인해 잘못된 비교로 이어질 수 있습니다. 이 문제를 해결하려면 DECIMAL 유형을 대신 사용하는 것이 좋습니다.

부동 소수점 산술의 고유 부정확성

부동 소수점 숫자는 제한된 정밀도로 저장되므로 약간의 오차가 발생할 수 있습니다. 계산 중 부정확함. 예를 들어, MySQL에 부동 소수점으로 저장된 숫자 50.12를 생각해 보세요.

CREATE TABLE users (points FLOAT);
INSERT INTO users (points) VALUES (50.12);
로그인 후 복사

> 연산자를 사용하여 이 값을 12.75와 비교하면 50.12가 12.75보다 크더라도 MySQL은 "False"를 반환합니다.

SELECT COUNT(*) FROM users WHERE points > 12.75;
로그인 후 복사

DECIMAL의 장점

이러한 불일치를 방지하기 위해 DECIMAL 데이터 유형은 고정된 정밀도와 소수 자릿수를 제공하여 계산과 비교가 정확하도록 보장합니다. 예:

ALTER TABLE users MODIFY COLUMN points DECIMAL(6,2);
UPDATE users SET points = 50.12;
SELECT COUNT(*) FROM users WHERE points > 12.75;
로그인 후 복사

이제 비교 결과는 의도한 대로 "True"를 반환합니다.

추가 고려 사항

  • 기본값 사용 NULL 값을 방지하면서 부동 소수점 열의 기본값을 지정하는 키워드입니다.
  • 반올림 오류를 완화하려면 비교를 수행하기 전에 ROUND() 또는 TRUNCATE() 함수를 사용하는 것이 좋습니다.

위 내용은 MySQL이 부동 소수점 값을 비교하는 데 어려움을 겪는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿