laravel+Mysql 中DB原生SQL操作报1292 Truncated incorrect DOUBLE value问题解决

本文介绍了一次解决MySQL批量更新操作中出现1292 Truncated incorrect DOUBLE value错误的经历,通过修正SQL语句中的连接操作符从加号'+'改为CONCAT函数,最终解决了问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

报1292 Truncated incorrect DOUBLE value问题的,基本都是因为SQL写的不标准或者写错了。

昨天接到一个批量更新的需求。因为laravel不支持批量的更新操作,故使用了原生的sql进行拼接(可能laravel支持批量,我不知道)。

在做一个批量更新的操作的时候,提示报错!

错误如下:


上面错误简单说就是SQL有问题,我自认为是没有问题的啊。

我把SQL语句放到Navicat for Mysql中,执行发现是正常的。

SQL语句:


执行结果成功:


在代码里面执行不成功!把SQL拿出来运行没有一点问题。真实日了狗了!

难道是上次朋友聚餐,少喝了杯酒,把人品也弄差了?????


百度了下,很多1292 Truncated incorrect DOUBLE value 问题的,基本上的回答都是说SQL写的有问题的。

我仔细看了下SQL,还真有个地方写的不标准。在 point_history.memo这行的赋值使用了“+”。一般我们为了图方便都是使用+ 号的,标准的写法应该是使用函数CONCAT()。

把语句转换为point_history.memo = CONCAT(point_history.memo, '2017-11-17 10:30:22 由管理员强制转为有效状态;') 后,执行成功!


小结

这个问题主要还是日常的书写习惯造成的,建议大家在操作的时候,尽量按照标准格式进行书写。否则有时候真不知道问题出在什么地方。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

沛哥儿

您的鼓励是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值