SQL Server에서는 숫자가 아닌 nvarchar 데이터를 정수로 변환하려고 할 때 문제가 발생합니다. 이러한 시나리오를 효과적으로 처리하려면 변환 실패 시 반환할 기본값이나 NULL을 지정하는 것이 필수적입니다.
다행히 T-SQL은 CAST와 CASE 문. 작동 방식을 살펴보겠습니다.
DECLARE @text AS NVARCHAR(10)
이 줄은 최대 길이가 10자인 "@text"라는 변수를 선언하여 nvarchar 데이터를 저장할 수 있도록 합니다.
SET @text = '100'
다음 , 변수 "@text"에는 유효한 정수인 "100" 값이 할당됩니다.
SELECT CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END
이 줄은 CASE 문을 활용하여 "@text" 값이 숫자인지 여부를 평가합니다. 1(True)을 반환하면 CAST 함수는 "@text"를 정수로 변환합니다. 숫자가 아닌 경우 명령문은 NULL을 반환합니다.
ISNUMERIC 함수는 이 프로세스에서 중요한 역할을 합니다. 그러나 기호($) 또는 구분 기호(.)가 포함된 문자열을 숫자로 처리할 수 있는 가능성과 같이 Fedor Hajdu가 언급한 제한 사항에 주목할 가치가 있습니다. 이는 특정 유형의 데이터로 작업할 때 중요한 고려 사항입니다.
결론적으로 CASE 문을 CAST 및 ISNUMERIC과 함께 사용하면 개발자가 잠재적인 변환 실패를 처리하면서 nvarchar 데이터를 정수로 손쉽게 변환할 수 있습니다. T-SQL 결과의 무결성과 정확성.
위 내용은 T-SQL의 기본값을 사용하여 NVARCHAR을 INT로 안전하게 캐스팅하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!