다음을 통해 공유


TRY_CAST(Transact-SQL)

캐스트에 성공하면 지정한 데이터 형식으로 캐스팅된 값을 반환합니다. 그렇지 않으면 Null을 반환합니다.

적용 대상: SQL Server(SQL Server 2012 - 현재 버전), Windows Azure SQL 데이터베이스(최초 릴리스 - 현재 릴리스)

항목 링크 아이콘 Transact-SQL 구문 표기 규칙

구문

TRY_CAST ( expression AS data_type [ ( length ) ] )

인수

  • expression
    캐스팅할 값입니다. 유효한 식입니다.
  • data_type
    expression을 캐스팅할 데이터 형식입니다.

  • length
    대상 데이터 형식의 길이를 지정하는 선택적 정수입니다.

    허용되는 값 범위는 data_type 값에 따라 결정됩니다.

반환 형식

캐스트에 성공하면 지정한 데이터 형식으로 캐스팅된 값을 반환합니다. 그렇지 않으면 Null을 반환합니다.

주의

TRY_CAST 함수는 전달된 값을 사용하여 지정된 data_type으로 변환합니다. 캐스팅에 성공하면 TRY_CAST는 지정된 data_type으로 값을 반환합니다. 오류가 발생하면 Null이 반환됩니다. 그러나 명시적으로 허용되지 않는 변환을 요청하면 오류와 함께 TRY_CAST가 실패합니다.

TRY_CAST는 예약 키워드가 아니며 모든 호환성 수준에서 사용할 수 있습니다. 원격 서버에 연결할 때 TRY_CAST는 TRY_CONVERT와 동일한 의미 체계를 갖습니다.

1.TRY_CAST가 null을 반환

다음 예에서는 캐스팅을 실패할 때 TRY_CAST가 null을 반환하는 것을 보여 줍니다.

SELECT 
    CASE WHEN TRY_CAST('test' AS float) IS NULL 
    THEN 'Cast failed'
    ELSE 'Cast succeeded'
END AS Result;
GO

결과 집합은 다음과 같습니다.

Result
------------
Cast failed

(1 row(s) affected)

다음 예에서는 식이 해당 형식에 맞아야 한다는 것을 보여 줍니다.

SET DATEFORMAT dmy;
SELECT TRY_CAST('12/31/2010' AS datetime2) AS Result;
GO

결과 집합은 다음과 같습니다.

Result
----------------------
NULL

(1 row(s) affected)

2.TRY_CAST가 오류와 함께 실패

다음 예에서는 캐스팅이 명시적으로 허용되지 않은 경우 TRY_CAST가 오류를 반환하는 것을 보여 줍니다.

SELECT TRY_CAST(4 AS xml) AS Result;
GO

정수는 xml 데이터 형식으로 캐스팅될 수 없으므로 이 문을 실행하면 오류가 발생합니다.

Explicit conversion from data type int to xml is not allowed.

3.TRY_CAST 성공

이 예에서는 식이 해당 형식에 맞아야 한다는 것을 보여 줍니다.

SET DATEFORMAT mdy;
SELECT TRY_CAST('12/31/2010' AS datetime2) AS Result;
GO

결과 집합은 다음과 같습니다.

Result
----------------------------------
2010-12-31 00:00:00.0000000

(1 row(s) affected)

참고 항목

참조

TRY_CONVERT(Transact-SQL)

CAST 및 CONVERT(Transact-SQL)