一个很基础的插入语句:
insert into table1select 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 ...时写明列名是很有必要的,仅记与此。