使用MybatisPlus报错,Error getting generated key or setting result to parameter object

本文主要是介绍使用MybatisPlus报错,Error getting generated key or setting result to parameter object,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

做项目时遇到一个很奇怪的错误,明明数据库设置了主键ID自增,并且实体类上也加了自增的注解
在这里插入图片描述
但是在插入一条数据时却遇到了以下报错。

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.
ExecutorException: Error getting generated key or setting result to parameter object. 
Cause: org.apache.ibatis.executor.result.ResultMapException:Error attempting to get column #1 from result set.  Cause: java.sql.SQLDataException: Value '18,446,744,073,709,549,608' is outside of valid range for type java.lang.Long

错因是因为在默认情况下不设置id会按照数据库自增,但是设置了id就会按照设置的id插入数据库。我将id设置成了负数,在插入数据库时,可能是因为二进制补码之类的规则,虽然执行的sql语句没有将系统生成的自增id真正插入到数据库,但是缺映射到了实体类对象,而这个id超出了Long的范围,所以发生了报错。

以下时实际执行的sql语句:

 Execute SQLINSERT INTO jtcf_planning_report_expenditure ( id, user_id, project_name, use_after_years, every_year_cost, continued_cost_year, order_id, create_by, create_time, update_time, update_by ) VALUES ( -2008, 50, '幸福养老', -5, 0.00600000, 42, 75, 'admin', '2023-03-01T00:29:12.139+0800', '2023-03-01T00:29:12.139+0800', 'admin' )

由于默认情况下又需要自增id的逻辑,而对于特定的业务逻辑需要设置id后插入,故不能将id设置为用户输入的,即:
在这里插入图片描述

最终的解决办法是使用注解编写SQL语句避免上述映射问题,并且能够在特定场景下设置id插入。

    /*** 解决 Error getting generated key or setting result to parameter object值映射回填实体类对象超过Long范围错误* @Options 自定义是否使用生成的主键值*/@Insert("<script>" +"INSERT INTO jtcf_planning_report_expenditure " +"(id,continued_cost_year,every_year_cost,project_name,user_id,order_id,use_after_years) " +"VALUES (#{id},#{continuedCostYear},#{everyYearCost},#{projectName},#{userId},#{orderId},#{useAfterYears}) " +"</script>")@Options(useGeneratedKeys = false,keyProperty = "id",keyColumn = "id")void saveNotUseGeneratedKey(PlanningReportExpenditure p);

这篇关于使用MybatisPlus报错,Error getting generated key or setting result to parameter object的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/406129

相关文章

C语言中联合体union的使用

本文编辑整理自: http://bbs.chinaunix.net/forum.php?mod=viewthread&tid=179471 一、前言 “联合体”(union)与“结构体”(struct)有一些相似之处。但两者有本质上的不同。在结构体中,各成员有各自的内存空间, 一个结构变量的总长度是各成员长度之和。而在“联合”中,各成员共享一段内存空间, 一个联合变量

#error用法

/* *检查编译此源文件的编译器是不是C++编译器 *如果使用的是C语言编译器则执行#error命令 *如果使用的是 C++ 编译器则跳过#error命令 */ #ifndef __cplusplus #error 亲,您当前使用的不是C++编译器噢! #endif #include <stdio.h> int main() {

Tolua使用笔记(上)

目录   1.准备工作 2.运行例子 01.HelloWorld:在C#中,创建和销毁Lua虚拟机 和 简单调用。 02.ScriptsFromFile:在C#中,对一个lua文件的执行调用 03.CallLuaFunction:在C#中,对lua函数的操作 04.AccessingLuaVariables:在C#中,对lua变量的操作 05.LuaCoroutine:在Lua中,

ITMS-90339: Deprecated Info.plist Key

The Info.plist contains a key 'UIApplicationExitsOnSuspend' in bundle 在info.plist中找到这个key——UIApplicationExitsOnSuspend,然后删掉就可以了。确保没问题的话也跑一下看是否可以能在后台运行。 需要先转换一下,才能找到对应的key

Vim使用基础篇

本文内容大部分来自 vimtutor,自带的教程的总结。在终端输入vimtutor 即可进入教程。 先总结一下,然后再分别介绍正常模式,插入模式,和可视模式三种模式下的命令。 目录 看完以后的汇总 1.正常模式(Normal模式) 1.移动光标 2.删除 3.【:】输入符 4.撤销 5.替换 6.重复命令【. ; ,】 7.复制粘贴 8.缩进 2.插入模式 INSERT

Lipowerline5.0 雷达电力应用软件下载使用

1.配网数据处理分析 针对配网线路点云数据,优化了分类算法,支持杆塔、导线、交跨线、建筑物、地面点和其他线路的自动分类;一键生成危险点报告和交跨报告;还能生成点云数据采集航线和自主巡检航线。 获取软件安装包联系邮箱:2895356150@qq.com,资源源于网络,本介绍用于学习使用,如有侵权请您联系删除! 2.新增快速版,简洁易上手 支持快速版和专业版切换使用,快速版界面简洁,保留主

如何免费的去使用connectedpapers?

免费使用connectedpapers 1. 打开谷歌浏览器2. 按住ctrl+shift+N,进入无痕模式3. 不需要登录(也就是访客模式)4. 两次用完,关闭无痕模式(继续重复步骤 2 - 4) 1. 打开谷歌浏览器 2. 按住ctrl+shift+N,进入无痕模式 输入网址:https://www.connectedpapers.com/ 3. 不需要登录(也就是

Toolbar+DrawerLayout使用详情结合网络各大神

最近也想搞下toolbar+drawerlayout的使用。结合网络上各大神的杰作,我把大部分的内容效果都完成了遍。现在记录下各个功能效果的实现以及一些细节注意点。 这图弹出两个菜单内容都是仿QQ界面的选项。左边一个是drawerlayout的弹窗。右边是toolbar的popup弹窗。 开始实现步骤详情: 1.创建toolbar布局跟drawerlayout布局 <?xml vers

C#中,decimal类型使用

在Microsoft SQL Server中numeric类型,在C#中使用的时候,需要用decimal类型与其对应,不能使用int等类型。 SQL:numeric C#:decimal

探索Elastic Search:强大的开源搜索引擎,详解及使用

🎬 鸽芷咕:个人主页  🔥 个人专栏: 《C++干货基地》《粉丝福利》 ⛺️生活的理想,就是为了理想的生活! 引入 全文搜索属于最常见的需求,开源的 Elasticsearch (以下简称 Elastic)是目前全文搜索引擎的首选,相信大家多多少少的都听说过它。它可以快速地储存、搜索和分析海量数据。就连维基百科、Stack Overflow、