SQL Server datetime类型转换超出范围的报错

Posted Leohahah

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL Server datetime类型转换超出范围的报错相关的知识,希望对你有一定的参考价值。

一个很基础的插入语句:

insert into table1
select col1,convert(datetime,col2),convert(datetime,col3),col4,col5 from table2

其中table1表中col2,col3是datetime类型,其他都是varchar类型,table2全部是varchar类型。

  table2表中全部是varchar类型,col 1 4 5都有可能是空值。

在执行时报出如下错误:

消息 242,级别 16,状态 3,第 1 行
从 varchar 数据类型到 datetime 数据类型的转换产生一个超出范围的值。
语句已终止。

由于datetime类型的只涉及到了col 2 3两列,因此检查了好长时间这两列的数据是否规范,但是最后发现并不是不规范数据的问题。

插入语句写成:

insert into table1(col1,col2,col3,col4,col5) 
select col1,convert(datetime,col2),convert(datetime,col3),col4,col5 from table2

则不会报错,应该是未能写明列名,导致匹配时其他列的值匹配到datetime列导致,因此sqlserver insert into ... select ...时写明列名是很有必要的,仅记与此。

以上是关于SQL Server datetime类型转换超出范围的报错的主要内容,如果未能解决你的问题,请参考以下文章

从 Excel 导入 SQL Server:将 varchar 数据类型转换为 datetime 数据类型导致值超出范围

[SQL Server]从 varchar 数据类型到 datetime 数据类型的转换产生一个超出范围的值。

错误 sql:将 varchar 数据类型转换为 datetime 数据类型导致值超出范围

将 varchar 数据类型转换为 datetime 数据类型导致值超出范围的问题

将 varchar 数据类型转换为 datetime 数据类型导致 SQL 查询中的值超出范围

SQL Server 将字符串转换为日期时间