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

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

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-07 19:47:03956검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.