≡
  • 网络编程
  • 数据库
  • CMS技巧
  • 软件编程
  • PHP笔记
  • JavaScript
  • MySQL
位置:首页 > 数据库 > SQL Server

SQL Server中T-SQL 数据类型转换的简单示例

人气:397 时间:2020-06-11

这篇文章主要为大家详细介绍了SQL Server中T-SQL 数据类型转换的简单示例,具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随四海网的小编两巴掌来看看吧!

常用的转换函数是 cast 和 convert,用于把表达式得出的值的类型转换成另一个数据类型,如果转换失败,该函数抛出错误,导致整个事务回滚。在SQL Server 2012版本中,新增两个容错的转换函数:try_cast 和 try_convert,如果转换操作失败,该函数返回null,不会导致整个事务失败,事务继续执行下去。

注意:对于SQL Server显式定义的不合法转换,try_cast 和 try_convert 会失败,抛出错误信息:Explicit conversion from data type int to date is not allowed.

代码如下:


select try_cast(1 as date)
转换函数是parse 和 try_parse,只用于把字符类型转换为 date/time 和 数字类型,在解析字符时会产生一定的性能消耗。

 

一,时间类型转换

 

在把日期/时间类型转换成字符串时,常用的转换函数是Convert和Cast,convert函数能够在一定程度上显式控制日期/时间的显示格式,而cast对日期/时间类型的显示格式,无法显式控制,我推荐使用另一个功能更强大的函数:FORMAT,该函数用于把日期时间类型,按照指定的格式转换成字符串,也可以把数值按照特定的格式输出。

1,常用的转换函数

convert 常用于转换date,datetime 等日期/时间类型,通过指定style参数,能够控制数据显示的格式

代码如下:


CAST ( expression AS data_type [ ( length ) ] )
CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
常用的style及其显示格式如下:

101 mm/dd/yyyy 110 mm-dd-yyyy 111 yyyy/mm/dd 112 yyyymmdd 120 yyyy-mm-dd hh:mm:ss 121 yyyy-mm-dd hh:mm:sssssss

CONVERT函数的style是数字,记忆起来比较困难,只能按照系统定义的格式来显示,不够灵活。SQL Server提供更为灵活的转换函数FORMAT。

2,FORMAT函数,控制日期和时间类型的显示格式

FORMAT函数主要用于格式化显示date/time类型和数值类型,参数format用于指定显示的格式,给予用户对格式更自由地控制,culture参数是可选的,用于指定显示的语言,该函数返回值的数据类型是NVARCHAR,如果格式转换失败,该函数返回NULL:

代码如下:


FORMAT ( value, format [, culture ] ) 
当转换date/time时,在format参数中指定日期/时间显示的格式,通常情况下,日期/时间的格式使用以下关键字符作为占位符:yyyy、MM、dd用来表示:年、月、日,而hh、mm、ss用来表示:时、分、秒,并使用“/”,“-”等作为连接符,例如:

代码如下:


DECLARE @d DATETIME = GETDATE(); 
SELECT FORMAT( @d, 'dd/MM/yyyy', 'en-US' ) AS 'DateTime Result' 
当转换数值类型时,在参数format中使用#代表一个数字,使用相应的连接符,拼接成数字的格式字符,例如:

代码如下:


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)

本文来自:http://www.q1010.com/179/9094-0.html

注:关于SQL Server中T-SQL 数据类型转换的简单示例的内容就先介绍到这里,更多相关文章的可以留意四海网的其他信息。

关键词:SQL SERVER

您可能感兴趣的文章

  • 解决SqlServer 各版本 sa帐户不能登录问题
  • Windows使用性能监视器监控SqlServer的常见指标示例
  • 调整SQLServer2000运行数据库结构的简单示例
  • 解决SQLServer远程连接失败的问题
  • 数据库触发器DB2和SqlServer区别解析
  • 解决在Azure上部署Sqlserver网络访问不了示例
  • 在sqlserver中如何使用CTE解决复杂查询问题
  • SqlServer应用之sys.dm_os_waiting_tasks 引发的疑问(下)
  • SqlServer如何通过SQL语句获取处理器(CPU)、内存(Memory)、磁盘(Disk)以及操作系统相关信息
  • SQLServer中merge函数用法分析
上一篇:SQL Server必备 SQL 查询优化提升网站访问速度的简单示例
下一篇:SQL Server SSIS 延迟验证示例
热门文章
  • SQL Server SQL获取第一条记录的方法
  • SQL Server出现System.OutOfMemoryException异常的解决方法
  • SQL Server的 update from 语句的简单示例
  • SQL Server 数据库备份方法菜鸟教程
  • SQL Server 多表关联时在where语句中慎用trim()方法
  • SQL Server数据类型及长度限制详细说明
  • mybaits非配置原因,导致SqlSession was not registered for synchronization异常解析
  • SQL Server 收缩后对数据库的使用有影响吗?
  • SQL Server 格式导致的Excel导入sql出现异常的解决方法
  • SQL Server 连接服务器出现错误 7391的解决方法
  • 最新文章
    • SQL Server存储过程基本语法的简单示例
    • sql查询时增加自动编号和分页的简单示例
    • sql轻松应付百万数据的高效数据分页存储过程的简单示例
    • sql获取一条数据中所有字段的名称和值的实现方法
    • sql分割函数的简单示例
    • SQL Server异常捕获的简单示例
    • SQL SERVER回滚恢复误操作数据的实现方法
    • SQL Server函数或存储过程中抛出异常的实现方法
    • SQL Server创建数据库的完整代码
    • SQL Server创建数据库的命令用法示例

四海网收集整理一些常用的php代码,JS代码,数据库mysql等技术文章。