SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2403字,纯文字阅读大概需要4分钟。
内容图文
![SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别](/upload/InfoBanner/zyjiaocheng/459/096bd278074e4562b6046615b2ba5aca.jpg)
TRY_PARSE是用于将字符串类型的数据转换成时间或者数值类型的数据。它是一个基于.NET CLR Runtime的标量函数。语法是TRY_PARSE(<string/string column> AS <data_type> [USING <culture>])
下面做一个字符串转时间的实验:
SQL Server 版本:
Microsoft SQL Server 2014
Enterprise Edition (64-bit) on Windows NT 6.3 <X64>
SELECT TRY_PARSE(‘20150901‘ AS DATETIME), TRY_CAST(‘20150901‘ AS DATETIME), TRY_CONVERT(DATETIME,‘20150901‘) SELECT TRY_PARSE(‘2015/09/01‘ AS DATETIME), TRY_CAST(‘2015/09/01‘ AS DATETIME), TRY_CONVERT(DATETIME,‘2015/09/01‘) SELECT TRY_PARSE(‘2015/09/01 14:14:45‘ AS DATETIME), TRY_CAST(‘2015/09/01 14:14:45‘ AS DATETIME), TRY_CONVERT(DATETIME,‘2015/09/01 14:14:45‘) SELECT TRY_PARSE(‘2015/09/01 14:14:45‘ AS DATETIME), TRY_CAST(‘2015/09/01 14:14:45‘ AS DATETIME), TRY_CONVERT(DATETIME,‘2015/09/01 14:14:45‘) SELECT TRY_PARSE(‘2015/09/01 14:14:45+0001‘ AS DATETIME), TRY_CAST(‘2015/09/01 14:14:45+0001‘ AS DATETIME), TRY_CONVERT(DATETIME,‘2015/09/01 14:14:45+0001‘)
上面代码输出的结果如下图所示
可以看到TRY_PARSE在将纯数字转为DATETIME的情况下居然失效,这点让我非常意外,而且我尝试了DATE类型也是一样的结果。
而如果加了像"-"或者"/"这样的时间分隔符则三个函数都能转换成功。
还有一点让我惊讶的是TRY_CAST和TRY_CONVERT不支持带有时区的转换,而TRY_PARSE则可以。
而当我把第四行代码的冒号修改成中文下面的冒号时则SQL Server辨认不出来。
TRY_CAST和TRY_CONVERT:
这一对更多是CAST和CONVERT这对函数的变体,语法上一样,只是当无法成功转换的时候是报错或者输出NULL值。
三者的区别总结如下:
1)TRY_PARSE只支持字符转数值或者时间类型,而TRY_CAST和TRY_CONVERT支持更多的类型;
2)三者有一点比较好的就是对于字符的空格处理,只要空格在处在分割符号的前后像“2015/ 09/ 10”这样是可以被成功处理的,但是如果空格隔开本身就是一个整体的数据值部分,则全部不能识别,像“2015/0 9/10”。
2)TRY_PARSE由于是CLR写的函数,对于源数据的数据格式支持比较广或者要求比较宽松,而TRY_CAST和TRY_CONVERT则要求比较严格。这点从上面的例子中,TRY_PARSE支持带有时区的时间格式而其他两个不支持就可以看出。而TRY_PARSE的支持范围远不止于此。
下面这个例子就证明了TRY_PARSE是仅最大的努力和可能去转换数据,而后两者则需要很严格数据格式
SELECT TRY_PARSE(‘Thursday, 19 Nov 2015‘ AS DATETIME) SELECT TRY_CONVERT(DATETIME, ‘Thursday, 19 Nov 2015‘);
SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别
标签:
本文系统来源:http://www.cnblogs.com/jenrrychen/p/4976429.html
内容总结
以上是互联网集市为您收集整理的SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别全部内容,希望文章能够帮你解决SQL Server ->> 内置标量函数TRY_PARSE、TRY_CAST和TRY_CONVERT的各自特点和区别所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。