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"를 반환합니다.
추가 고려 사항
위 내용은 MySQL이 부동 소수점 값을 비교하는 데 어려움을 겪는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!