>데이터 베이스 >MySQL 튜토리얼 >SQL Server의 소수 값에서 후행 0을 제거하려면 어떻게 해야 합니까?

SQL Server의 소수 값에서 후행 0을 제거하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-14 13:42:44336검색

How Can I Remove Trailing Zeros from Decimal Values in SQL Server?

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

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