sql执行报错Truncated incorrect time value的解决方法

一、前言

最近修改生产库,需要更新一批数据。

1.首先,执行了这个sql:

select count(*) from class_subject 
where endtime is not null and starttime is not null and round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)!=round(hour,1)

就是查询下结束时间-开始时间!=hour的数据,这个执行没有问题

2.然后,执行这个sql,就报错了:

update class_subject set hour=round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)
where endtime is not null and starttime is not null and round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)!=round(hour,1)

就是想设置下hour=结束时间-开始时间,但是报错:

SQL错误[1292][22001]:Data truncation:Truncated incorrect time value:
'2616:30:00'

二、排查过程

百度发现,有的说:

1.根本原因是这个函数是算两个日期的时间差,但是他的取值最大只到838:59:59(不到35天),如果超过就会报错

但是我们排查了下数据库数据,round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)的结果最多只差3小时,不存在超过35天的情况。

三、解决方法

首先我们的目标是更新数据库的一批数据,其次发现执行select是没有问题的,因此我们决定查询出所有数据的id与待更新的值来,一条一条批量更新。

1.使用了sql:

select id, round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)!=round(hour,1) as hour from class_subject 
where endtime is not null and starttime is not null and round(TIME_TO_SEC(TIMEDIFF(endtime,starttime))/60/60,1)!=round(hour,1)

这样可以查询到待修改数据的id,以及需要修改的目标hour值

2.使用excel,把数据批量拼接成以下格式:

update class_subject set hour='xxx' where id='xxx';
update class_subject set hour='xxx' where id='xxx';
update class_subject set hour='xxx' where id='xxx';

3.然后,一条一条批量更新,就绕过了这个报错,更新数据成功。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据你提供的引用内容,你遇到了一个关于更新语句报错的问题,错误信息是"Truncated incorrect DOUBLE value: 'I4210'"。根据网上的解决办法,你可以尝试以下方法解决这个问题: 1. 检查数据类型:首先,你需要检查被更新的字段的数据类型是否正确。如果被更新的字段是一个DOUBLE类型的字段,那么确保你提供的值也是DOUBLE类型的。如果不是,你需要将值转换为DOUBLE类型再进行更新。 2. 使用引号:如果你提供的值是一个字符串,确保你在更新语句中使用了引号将其括起来。如果没有使用引号,数据库可能会将其解析为DOUBLE类型,从而导致错误。 3. 检查数据格式:检查被更新的字段的数据格式是否正确。如果字段的数据格式要求是特定的,确保你提供的值符合该格式要求。如果不符合,你需要对值进行格式化或转换。 4. 检查特殊字符:如果你的值中包含特殊字符,例如单引号或双引号,确保你对这些特殊字符进行了转义或处理,以避免引起语法错误。 5. 使用参数化查询:如果你使用的是SQL语句拼接的方式来构建更新语句,建议改为使用参数化查询。参数化查询可以帮助你正确处理数据类型和特殊字符,避免出现错误。 下面是一个示例代码,演示了如何使用参数化查询来解决这个问题: ```java String value = "I4210"; String sql = "UPDATE table_name SET column_name = ? WHERE condition = ?"; PreparedStatement statement = connection.prepareStatement(sql); statement.setString(1, value); statement.setString(2, condition); statement.executeUpdate(); ``` 请注意,上述代码中的"table_name"、"column_name"和"condition"需要替换为你实际使用的表名、字段名和条件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

追逐梦想永不停

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值