1 场景复现

  • MySQL: 5.7.24-27
  • 表结构

    (两张独立的表)
[表 RRR1]
CREATE TABLE `RRR1` (
`R1` float NOT NULL COMMENT 'R1',
`R2` float NOT NULL COMMENT 'R2'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='RRR1'; [表 Person11]
CREATE TABLE `Person11` (
`CSSJY111` varchar(3) DEFAULT NULL COMMENT '测试数据元011',
`CSSJY107` int(3) DEFAULT NULL COMMENT '测试数据元007',
`CSSJY106` int(3) DEFAULT NULL COMMENT '测试数据元006',
`CSSJY112` datetime DEFAULT NULL COMMENT '测试数据元012',
`CSSJY103` varchar(10) DEFAULT NULL COMMENT '测试数据元003',
`CSSJY113` blob COMMENT '测试数据元013',
`CSSJY104` varchar(10) DEFAULT NULL COMMENT '测试数据元004',
`CSSJY108` varchar(10) DEFAULT NULL COMMENT '测试数据元008',
`CSSJY102` varchar(10) DEFAULT NULL COMMENT '测试数据元002',
`CSSJY109` varchar(10) DEFAULT NULL COMMENT '测试数据元009',
`CSSJY101` varchar(10) DEFAULT NULL COMMENT '测试数据元101',
`CSSJY110` date DEFAULT NULL COMMENT '测试数据元010',
`CSSJY105` int(3) DEFAULT NULL COMMENT '测试数据元005'
) ENGINE=InnoDB DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='个人信息';
  • 异常SQL
DELETE FROM
CJ_TEST.`RRR1`
WHERE `R1` IN (
SELECT * FROM (
SELECT `R1` FROM CJ_TEST.`RRR1` WHERE `R1` IN (
SELECT `CSSJY111` FROM (
SELECT `CSSJY111` FROM `CJ_TEST`.`Person11` ORDER BY `CSSJY112` ASC, `CSSJY111` LIMIT 3
) ttt -- 中间表 ttt
)
) B WHERE B.R1 = 1 -- 中间表 B
)

报异常:

[Err] 1292 - Truncated incorrect DOUBLE value: 'dc5'

翻译: [错误] 1292 - 数据截断:截断不正确的双精度值:'dc5'

注: MySQL数据库 必须带中间表 ttt 和 B,否则 查询会失败

MySQL数据库中 带中间表 可避免异常:[Err] 1093 - You can't specify target table 'tableName' for update in FROM clause

FROM clause : FROM 子句

(翻译: 你不能在DELETE/UPDATE这类修改操作的FROM子句中指定目标表——tableName。)

"不能先select出同一表中的某些值,再update这个表(在同一语句中)"

"不能在同一表中查询的数据作为同一表的更新数据"

"注意,这个问题只出现于mysql,mssql和Oracle不会出现此问题。" (博主尚未验证此结论)

原因: DELETE/UPDATE (修改)操作 表tableName时,其FROM子句的实际操作表是 FROM子句内的虚表(结果集)

解决办法:
1. 在select外边套一层括号"( 原SQL )",让数据库认为你不是查同一表的数据作为同一表的更新数据
2. 将select的结果集临时设置为中间表——`select * from ( 原select的结果集 ) TMP`,让修改操作的FROM对象为中间表

详见:MySQL之You can't specify target table for update in FROM clause解决办法 - CSDN

2 原因分析

源字段与目标字段的类型不一致!!!

异常SQL中:
源字段为 Person11表的CSSJY111字段(varchar(3))
目标字段为 RRR1表的R1字段(float)

3 解决方案

情况1: 源字段值A与目标字段值B的类型不一致

  • 解决方案1

修改数据库表的字段类型。

ALTER TABLE RRR1 MODIFY COLUMN R1 VARCHAR(3);
  • 解决方案2

sql_mode

(此方案不太推荐,但迫不得已时亦可使用)

SET SESSION sql_mode = '';

补充/延申: sql_mode的其它操作

select @@GLOBAL.sql_mode;
select @@SESSION.sql_mode; -- STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION SET SESSION sql_mode = 'STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION';

情况2: UPDATE的语法错误

网络博客中很多人更多遇到的是此类情况————语法错误

例如:update table set A = "a" and B = "b" where id = 1 (报错)

  • 解决方案

原SQL语句的 "and" 换成逗号 ","

update table set  A = "a" ,   B=  "b" where  id = 1 (正确)

Y 不足之处与反思

1 追根到底,本质上是什么原因导致的此异常? [√]

—— 此问题已解决 于 2020-10-14 21:14

2 sql_mode的配置起到了什么作用? [待解决]

3 为什么这么做可以成功解决? [√]

—— 此问题已基本解决 于 2020-10-14 21:14

X 参考与推荐文献

[数据库/MySQL]解决异常:Data truncation: Truncated incorrect DOUBLE value: 'dc5'的更多相关文章

  1. Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Truncated incorrect DOUBLE value: 'L

    1.错误叙述性说明 [ERROR:]2015-06-08 09:49:42,523 [异常拦截] org.hibernate.exception.DataException: error execut ...

  2. Caused by: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Truncated incorrect DOUBLE value: 'L

    1.错误描述 [ERROR:]2015-06-08 09:49:42,523 [异常拦截] org.hibernate.exception.DataException: error executing ...

  3. com.mysql.jdbc.MysqlDataTruncation: Data truncation: Truncated incorrect DOUBLE value:...

    在使用mybatis的@Update注解的时候,报了一个这样的错 ### Error updating database. Cause: com.mysql.jdbc.MysqlDataTruncat ...

  4. 异常-Data truncation: Truncated incorrect DOUBLE value: '-9370.3530-'

    1详细异常日志 9/11/04 17:36:09 ERROR base.SQLHelper: Data truncation: Truncated incorrect DOUBLE value: '- ...

  5. Error updating database. Cause: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Truncated incorrect DOUBLE value: 'as3'

    执行更新时的出错信息 Whitelabel Error Page This application has no explicit mapping for /error, so you are see ...

  6. Data truncation: Truncated incorrect DOUBLE value 解决方案

    1.情况限制 此处的错误解决方案只讨论: 在使用Mybatis时,传入数组且使用<foreach>标签时出现此种报错: 2.报错案例 mapper.java /** * @Descript ...

  7. java.sql.SQLException: Data truncation: Truncated incorrect DOUBLE value

    mysql 报这个异常:java.sql.SQLException: Data truncation: Truncated incorrect DOUBLE value update 表名 set c ...

  8. Data truncation: Truncated incorrect DOUBLE value:

    在写sql查询语句queryRunner.update(connection,"update account set balance=? where name=?",account ...

  9. Data truncation: Truncated incorrect DOUBLE value错误的解决方案

    Data truncation: Truncated incorrect DOUBLE value错误的解决方案: 当在修改某条单位记录时,发生了Data truncation: Truncated ...

  10. mysql 插入中文报错: com.mysql.jdbc.MysqlDataTruncation: Data truncation: Incorrect datetime value...

    总结写在前面, 总结: 当Java通过jdbc链接mysql插入中文时,要保证程序可以正常执行,而且插入的中文不会乱码, mysql服务器端,对数据表(不是数据库)的编码设置,要保证是支持中文的,例如 ...

随机推荐

  1. 从NCBI中下载各物种参考基因组

    1. 打开NCBI 2. 输入物种名,以HPV为例: 搜索,到genomes分栏下面选择Assembly点击进去 3. 进去下面的界面,再点击RefSeq进入下载界面 4. 进入下载界面: HPV参考 ...

  2. if (()) [[]] [] 条件表达式比较示例

    a.b的ASCII码是 097.098ASCII码 参考 http://www.51hei.com/mcu/4342.html 1. if (()) a=3; b=2 时,if (( a > b ...

  3. create-react-app react 使用dll抽离公共库,大幅缩减项目体积,及项目打包速度

    1.安装依赖(clean-webpack-plugin.add-asset-html-webpack-plugin.webpack-cli) yarn add clean-webpack-plugin ...

  4. ajax json php post 方法

    1.前端 <script type="text/javascript"> function LoadData(arg){ arg.dept=$("#DeptS ...

  5. Java jsp视频标签

    视频标签: 直接显示 <embed src="视频地址.mp4" width="60" height="40"> 按钮点击 &l ...

  6. IT工具知识-13: 如何编辑SVG图像文件并转换为ICO图标文件

    使用背景 最近做了个小软件, 但是桌面快捷方式图标不好看, 于是想着找个好看点的图标, 但是网上搜了一圈, 发现好看的几乎都要钱, 常用的话, 付费倒也不反感, 但是, 仅仅只用那么一两次, 为这个付 ...

  7. celery异步任务队列入门

    参考: Celery入门 任务调度delay&apply_async celery 简要概述 Celery 中文手册 Celery动态添加定时任务 全网最细之Celery 4.x动态添加定时任 ...

  8. 使用netty 实现本地代理程序

    本地代理程序1:将远程的服务设置为本地端口访问我的台式PC安装了vm,因为都是机器私有IP,但我的另外的PC电脑也需要访问方便测试,需要要把VM的端口设置在台式本机对外,这样我台式的端口对外在局域网都 ...

  9. centos虚拟机yum update报错Another app is currently holding the yum lock; waiting for it to exit...

    1.运行yum update报错 [root@localhost ~]# yum update已加载插件:fastestmirror, langpacks/var/run/yum.pid 已被锁定,P ...

  10. sql几种不同的权限

    DDL:Data Definition Language DDL允许用户定义数据,也就是创建表.删除表.修改表结构这些操作.通常,DDL由数据库管理员执行. DML:Data Manipulation ...