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 ...时写明列名是很有必要的,仅记与此。

  • 相关阅读:
    05-浮动/css
    04-选择器/css
    03-样式表/css
    02-html标签&表格&表单
    01-html基础&标签
    vue分页组件重置到首页问题
    VUE通过索引值获取数据不渲染的问题
    常见IE8兼容性问题及解决
    Ajax
    sea.js模块化工具
  • 原文地址:https://www.cnblogs.com/leohahah/p/7810622.html
Copyright © 2011-2022 走看看