zoukankan      html  css  js  c++  java
  • 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 ...时写明列名是很有必要的,仅记与此。

  • 相关阅读:
    CentOS6设置密码过期时间
    scp
    windows查看进程
    mysql5.7密码问题
    mysql主从切换摘要
    mysql慢日志管理
    Linux学习(一)
    Linux学习(一)
    数据结构与算法(1)-算法时间复杂度
    数据结构与算法(1)-算法时间复杂度
  • 原文地址:https://www.cnblogs.com/leohahah/p/7810622.html
Copyright © 2011-2022 走看看