MySQL의 DOUBLE 대 DECIMAL: 변환 인수 재평가
MySQL의 금융 데이터 저장에 DOUBLE을 사용하지 않는 것이 좋습니다. 잠재적인 정밀도 오류. 그러나 783개의 DOUBLE 열이 있는 기존 시스템의 경우 DECIMAL로의 변환을 고려하려면 신중한 평가가 필요합니다.
주어진 시나리오에서 시스템은 DOUBLE 열에 화폐 값을 저장하지만 BigDecimal을 사용하여 Java에서 모든 계산을 수행합니다. MySQL은 결과 저장에만 사용됩니다. 실제 데이터베이스 계산이 없기 때문에 DOUBLE의 정밀도 부족은 문제가 되지 않습니다.
게다가 시스템은 6년 동안 정밀도 관련 버그 없이 운영되었습니다. 이는 최대 8자리의 금융 값에 대해 DOUBLE의 15자리 정밀도이면 충분하다는 것을 의미합니다.
또한 수행되는 특정 데이터베이스 작업(SUM 및 복소 곱셈)으로 인해 초 단위의 정밀도가 손실되지 않습니다. 십진수. 이는 DOUBLE과 관련된 반올림 문제가 저장된 데이터의 정확성에 영향을 미치지 않음을 나타냅니다.
따라서 MySQL 외부에서 계산이 수행되고 정밀도가 중요한 문제가 아닌 이 특정 시나리오에서는 DOUBLE 열을 DECIMAL로 변환해야 하는 강력한 이유입니다. 그러나 향후 SQL 산술 연산이 계획된 경우 DECIMAL로의 변환을 재고해야 한다는 점에 유의해야 합니다.
위 내용은 외부에서 계산을 수행할 때 재무 데이터를 위해 MySQL에서 DOUBLE을 DECIMAL로 변환해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!