SQL Server 字符串转时间 数据验证

最近要从一个数据库将数据转移到另外一个数据库,期间涉及到一些字符串转时间类型出现了很多问题,将自己的一点愚见贴上来备忘。

CASE 
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.][1-9][-.][1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]0[1-9]-0[1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]0[1-9]-[1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.][1-9]-0[1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.][13456789][-.][12][0-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]0[13456789][-.][12][0-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.][13578][-.]3[01]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]0[13578][-.]3[01]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.][469][-.]30' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]0[469][-.]30' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]2[-.]1[0-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]02[-.]1[0-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]2[-.]2[0-8]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]02[-.]2[0-8]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]1[012][-.][1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]1[012][-.]0[1-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]1[012][-.][12][0-9]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]1[02][-.]3[01]' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
WHEN cnct_char31 LIKE '[12][0-9][0-9][0-9][-.]11[-.]30' THEN CAST(CONVERT(datetime,cnct_char31,120) AS VARCHAR)
ELSE NULL END

若有疑问或不正之处,欢迎提出指正和讨论。

转载于:https://www.cnblogs.com/iceknp/archive/2010/09/28/1837282.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值