SQL Server에서 소수점 값에서 후행 0을 제거하는 방법
많은 SQL Server 사용자는 십진수 값에 0이 뒤에 오는 일반적인 문제에 직면합니다. 예를 들어, 999,123456과 같은 값을 보유하도록 설계된 DECIMAL(9,6) 열은 123,4567을 123,456700으로 저장할 수 있습니다.
소수점 정밀도 이해
SQL Server의 DECIMAL 데이터 유형은 (9,6) 표기법에 표시된 것처럼 소수점 뒤에 특정 자릿수를 저장합니다. 이는 해당 열에 소수점 오른쪽 6자리가 포함될 수 있음을 의미합니다.
뒤에 오는 0에 대한 설명
정의된 정밀도를 유지하기 위해 소수점 값에 후행 0이 추가됩니다. 위의 예에서 값 123,4567은 소수점 이하 4자리만 있는데 6자리가 필요합니다. 따라서 끝에 두 개의 후행 0이 추가됩니다.
후행 0 제거
십진수 값에서 후행 0을 제거하려면 십진수를 부동 소수점으로 변환하는 솔루션을 사용할 수 있습니다.
<code class="language-sql">select cast(123.4567 as DECIMAL(9,6)) , cast(cast(123.4567 as float) as DECIMAL(9,4))</code>
이 방법은 부동 소수점 숫자가 기본적으로 후행 0을 표시하지 않는다는 점을 활용합니다. 소수점을 부동 소수점으로 변환한 다음 다시 소수점으로 변환하면 후행 0이 효과적으로 제거됩니다. 최종 결과는 유효한 소수 자릿수를 유지하면서 DECIMAL(9,4)로 변환됩니다.
출력 예
위 쿼리는 다음과 같은 출력을 생성합니다.
<code>123.456700 123.4567</code>
이 예에서는 마침표(.)가 소수 구분 기호 역할을 합니다. 소수점 값은 원래 정밀도를 유지하지만 뒤에 오는 0은 제거되었습니다. 정밀도 손실이나 불필요한 반올림을 방지하려면 적절한 정밀도(예: DECIMAL(9,4))를 선택하는 것이 최종 결과에 매우 중요합니다.
위 내용은 SQL Server의 소수 값에서 후행 0을 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!