SQL Server中T-SQL 数据类型转换详解

2020-07-04 06:04:43易采站长站整理


FORMAT(123456789,'###-##-####') AS 'Custom Number Result

二,容错的转换函数

TRY_CAST 和TRY_CONVERT是容错的转换函数,该函数尝试把表达式的值转换为指定的类型,如果转换成功,返回指定类型的值;如果尝试转换失败,返回NULL;如果请求把一个类型转换为另一个被显式禁止的数据类型,那么尝试转换失败,抛出错误消息,也就是说,尝试转换能够具有一定的容错,但是,不能做“违法”的转换操作。


TRY_CAST ( expression AS data_type [ ( length ) ] )
TRY_CONVERT ( data_type [ ( length ) ], expression [, style ] )

1,try_cast 返回null


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

2,try_cast 转换失败,返回error


SELECT TRY_CAST(4 AS xml) AS Result;

错误消息是: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;

4,try_convert常用于把date/time类型转换为指定格式的字符串

系统预定义Style,通过style参数指定最终显示date/time的格式


SELECT TRY_CONVERT(varchar(8),getdate(),112 ) AS Result;

三,转换的性能

转换函数的性能是不同的,经过测试,cast 和 convert 的转换性能最好,要比try_cast和try_convert要好一些;而Cast的转换性能比convert要好一点。

参考文档:

Performance Comparison of the SQL Server PARSE, CAST, CONVERT and TRY_PARSE, TRY_CAST, TRY_CONVERT Functions

CAST and CONVERT (Transact-SQL)

您可能感兴趣的文章:sqlserver2005 TSql新功能学习总结(数据类型篇)如何在SQL Server 2008下轻松调试T-SQL语句和存储过程SQLServer 2008 新增T-SQL 简写语法SQL Server 数据库管理常用的SQL和T-SQL语句通过T-SQL语句实现数据库备份与还原的代码SQL Server 数据库管理常用的SQL和T-SQL语句T-SQL中使用正则表达式函数T-SQL篇如何防止SQL注入的解决方法T-SQL 查询语句的执行顺序解析一些 T-SQL 技巧

相关文章 大家在看