T-SQL에서 문자열을 기본값을 사용하여 정수로 캐스팅
T-SQL에서는 문자열(nvarchar)을 캐스팅해야 하는 경우가 자주 발생합니다. ) 값을 정수(int) 데이터 유형으로 변환합니다. 그러나 문자열에 숫자가 아닌 문자가 포함되어 있으면 이 변환이 실패할 수 있습니다. 이러한 시나리오를 적절하게 처리하려면 변환에 실패할 경우 기본값이나 NULL을 반환해야 합니다.
이를 달성하려면 ISNUMERIC() 함수와 함께 CASE 표현식을 사용할 수 있습니다. ISNUMERIC()은 문자열이 유효한 숫자 값을 나타내는지 여부를 평가하여 true인 경우 1을 반환하고 false인 경우 0을 반환합니다.
구문:
CASE WHEN ISNUMERIC(@variable) = 1 THEN CAST(@variable AS INT) ELSE NULL END
예:
다음 사항을 고려하세요. 예:
DECLARE @text AS NVARCHAR(10) SET @text = '100' SELECT CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END -- returns 100 SET @text = 'XXX' SELECT CASE WHEN ISNUMERIC(@text) = 1 THEN CAST(@text AS INT) ELSE NULL END -- returns NULL
첫 번째 경우 '100'은 유효한 정수이므로 변환이 성공하여 값 100을 반환합니다. 두 번째 경우 'XXX'는 숫자 값이 아니므로 ISNUMERIC() 함수가 0을 반환하면 CASE 표현식이 반환됩니다. NULL.
고려 사항:
ISNUMERIC()에는 특정 제한 사항이 있다는 점에 주목할 가치가 있습니다. 예를 들어 통화 기호($), 구분 기호(,) 또는 (.) 및 산술 연산자( , -)가 포함된 문자열에 대해 true를 반환할 수 있습니다. 따라서 변환의 무결성을 보장하려면 추가 검증이 필요할 수 있습니다.
위 내용은 T-SQL에서 기본값을 사용하여 문자열을 정수로 안전하게 캐스팅하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!