decimal 및 numeric(Transact-SQL)
적용 대상: Microsoft Fabric의 Microsoft Fabric SQL 데이터베이스에 있는 Microsoft Fabric Warehouse의 SQL Server Azure SQL Managed Instance Azure Synapse Analytics Analytics Platform System(PDW) SQL 분석 엔드포인트
10진 수 및 숫자는 고정된 정밀도와 배율을 갖는 숫자 데이터 형식입니다. decimal 및 numeric 은 동의어이며 서로 교환하여 사용할 수 있습니다.
인수
decimal [ ( p [ , s ] ) ] and numeric [ ( p [ , s ] ) ]
고정 정밀도 및 배율 숫자입니다. 최대 정밀도를 사용하는 경우 유효한 값은 을 통해 10^38 - 1
가져옵니다-10^38 + 1
. 10진수에 대한 ISO 동의어는 12월과 12월(p,s)입니다. 숫자는 10진수와 기능적으로 동일합니다.
p (전체 자릿수)
저장할 최대 소수 자릿수입니다. 이 숫자에는 소수점의 왼쪽과 오른쪽이 모두 포함됩니다. 전체 자릿수 값은 1에서 최대 전체 자릿수인 38 사이여야 합니다. 기본 전체 자릿수는 18입니다.
참고 항목
Informatica는 지정된 정밀도 및 배율에 관계없이 16개의 유효 자릿수만 지원합니다.
s (scale)
소수점 오른쪽에 저장된 소수 자릿수입니다. 이 숫자는 p에서 빼서 소수점 왼쪽의 최대 자릿수를 결정합니다. 소수 자릿수는 0에서 p까지의 값이어야 하며 전체 자릿수가 지정된 경우에만 지정할 수 있습니다. 기본 눈금은 등입니다0
0 <= s <= p
. 전체 자릿수에 따라 최대 스토리지 크기가 달라집니다.
자릿수 | 스토리지 크기(바이트) |
---|---|
9개 항목 중 | 5 |
10-19 | 9 |
20-28 | 13 |
29-38 | 17 |
참고 항목
Informatica(SQL Server PDW Informatica Connector를 통해 연결)는 지정된 최대 자릿수 및 소수 자릿수와 상관없이 16 유효 자릿수만 지원합니다.
10진수 및 숫자 데이터 변환
decimal 및 numeric 데이터 형식의 경우 SQL Server는 전체 자릿수와 소수 자릿수의 각 조합을 다른 데이터 형식으로 간주합니다. 예를 들어 decimal (5,5) 및 decimal(5,0) 은 서로 다른 데이터 형식으로 간주됩니다.
Transact-SQL 문에서 소수점이 있는 상수는 필요한 최소 전체 자릿수 및 소수 자릿수를 사용하여 numeric 데이터 값으로 자동 변환됩니다. 예를 들어 상수 12.345
는 전체 자릿수5
와 배율3
로 숫자 값으로 변환됩니다.
B*에서 A*로의 변환이 | 변환을 | 변환 위험 |
---|---|---|
decimal 및 numeric | float 또는 real | 가능한 정밀도 손실 |
int, smallint, tinyint, float, real, money 또는 smallmoney | decimal 및 numeric | 가능한 오버플로 |
기본적으로 SQL Server는 숫자를 전체 자릿수 및 소수 자릿수가 낮은 decimal 또는 numeric 값으로 변환할 때 반올림을 사용합니다. 반대로 옵션인 SET ARITHABORT
ON
경우 오버플로가 발생할 때 SQL Server에서 오류가 발생합니다. 전체 자릿수 및 소수 자릿수의 손실만으로는 오류가 발생하지 않습니다.
SQL Server 2016(13.x) 이전에는 부동 소수점 값이 소수 또는 숫자로 변환되기 전에는 전체 자릿수 17자리 값으로만 제한됩니다. 과학적 표기법 또는 10진수 표0.000000000000000005
기법을 5E-18
사용하여 설정한 경우 보다 5E-18
작은 부동 소수점 값은 아래로 0
반올림됩니다. 이 제한은 SQL Server 2016(13.x) 이상 버전에는 표시되지 않습니다.
예제
다음 예제에서는 소수 및 숫자 데이터 형식을 사용하여 테이블을 만듭니다. 값은 각 열에 삽입됩니다. 결과는 문을 사용하여 SELECT
반환됩니다.
CREATE TABLE dbo.MyTable (
MyDecimalColumn DECIMAL(5, 2),
MyNumericColumn NUMERIC(10, 5)
);
GO
INSERT INTO dbo.MyTable
VALUES (123, 12345.12);
GO
SELECT MyDecimalColumn, MyNumericColumn
FROM dbo.MyTable;
결과 집합은 다음과 같습니다.
MyDecimalColumn MyNumericColumn
---------------- ----------------
123.00 12345.12000