问题解决:使用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);
相关推荐
Elastic 中国社区官方博客2 小时前
在 Elasticsearch 中使用 Mistral Chat completions 进行上下文工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
编程爱好者熊浪4 小时前
两次连接池泄露的BUG
java·数据库
TDengine (老段)5 小时前
TDengine 字符串函数 CHAR 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
qq7422349846 小时前
Python操作数据库之pyodbc
开发语言·数据库·python
姚远Oracle ACE6 小时前
Oracle 如何计算 AWR 报告中的 Sessions 数量
数据库·oracle
Dxy12393102166 小时前
MySQL的SUBSTRING函数详解与应用
数据库·mysql
码力引擎7 小时前
【零基础学MySQL】第十二章:DCL详解
数据库·mysql·1024程序员节
杨云龙UP7 小时前
【MySQL迁移】MySQL数据库迁移实战(利用mysqldump从Windows 5.7迁至Linux 8.0)
linux·运维·数据库·mysql·mssql
l1t7 小时前
利用DeepSeek辅助修改luadbi-duckdb读取DuckDB decimal数据类型
c语言·数据库·单元测试·lua·duckdb
安当加密7 小时前
Nacos配置安全治理:把数据库密码从YAML里请出去
数据库·安全