问题解决:使用Mybatis Plus的Mapper插入达梦数据库报“数据溢出”错误

前言

使用Mybatis Plus的Mapper插入达梦数据库报"数据溢出"错误

文章目录

问题描述

  1. 在进行批量插入中,抛出异常为数据溢出
    • 插入方法:this.baseMapper.insertBatchSomeColumn()
    • 抛出异常:数据溢出
  2. 对失败的数据进行循环,尝试使用单个插入的方法,同样抛出异常为数据溢出
    • 插入方法:this.baseMapper.insert
    • 抛出异常:数据溢出

错误日志输出

txt 复制代码
Cause: dm.jdbc.driver.DMException: 数据溢出
; 数据溢出; nested exception is dm.jdbc.driver.DMException: 数据溢出
	at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:104)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:70)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79)
	at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:79)

排查过程

  1. 使用异常断点:Breakpoints-> + Java Exception Breakpoints

  2. 找到调用栈中的执行方法:插入预处理执行的语句

  3. 发现语句中,如果实体字段定义为BigDecimal,其预处理的值是字符串格式

  4. 到达梦窗口工具-DM管理工具中进行测试验证

    1. 新增测试表:t_simple,包含字段height,类型及精度为DEC(4,2)

      sql 复制代码
      CREATE TABLE "t_simple"
      (
      "id" BIGINT NOT NULL,
      "name" VARCHAR(50),
      "height" DEC(4,2),
      NOT CLUSTER PRIMARY KEY("id")) STORAGE(ON "MAIN", CLUSTERBTR) ;
      
      COMMENT ON TABLE "t_simple" IS '测试表';
      COMMENT ON COLUMN "t_simple"."height" IS '身高(厘米)';
      COMMENT ON COLUMN "t_simple"."id" IS 'ID';
      COMMENT ON COLUMN "t_simple"."name" IS '姓名';
    2. 插入的值为字符串,出现报错:-6108: 字符串截断

      sql 复制代码
      insert into t_simple (height) values ('175.23');


    3. 插入的值为数字类型,报错:-6170: 列[xxx]精度超出定义

  5. 使用Mybatis Plus的BaseMapper.insert插入的时候,当实体字段为BigDemical类型的,会转换成字符串,最后报错:达梦数据库异常,数据溢出

最终解决办法

备注:标度为小数点后的位数,如DEC(4,2)包含了2个小数,则整数有4-2

  1. 增大表字段类型的精度

    sql 复制代码
    alter table "t_simple" modify "height" DEC(5, 2);
  2. 测试插入值为字符串:插入成功

    sql 复制代码
    insert into t_simple (id,height) values (1,'175.23');
  3. 测试插入值为数字类型:插入成功

    sql 复制代码
    insert into t_simple (id,height) values (1,175.23);
相关推荐
jiayou642 小时前
KingbaseES 实战:审计追踪配置与运维实践
数据库
NineData14 小时前
NineData 迁移评估功能正式上线
数据库·dba
NineData19 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师21 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区5 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript