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

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

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

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

错误如下:

laravel+Mysql 中DB原生SQL操作报1292 Truncated incorrect DOUBLE value问题解决_第1张图片

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

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

SQL语句:

laravel+Mysql 中DB原生SQL操作报1292 Truncated incorrect DOUBLE value问题解决_第2张图片

执行结果成功:

laravel+Mysql 中DB原生SQL操作报1292 Truncated incorrect DOUBLE value问题解决_第3张图片

在代码里面执行不成功!把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 由管理员强制转为有效状态;') 后,执行成功!


小结

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



你可能感兴趣的:(数据库)