>데이터 베이스 >MySQL 튜토리얼 >T-SQL에서 기본값을 사용하여 문자열을 정수로 안전하게 캐스팅하는 방법은 무엇입니까?

T-SQL에서 기본값을 사용하여 문자열을 정수로 안전하게 캐스팅하는 방법은 무엇입니까?

DDD
DDD원래의
2025-01-03 01:05:39734검색

How to Safely Cast Strings to Integers with Default Values in T-SQL?

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

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