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

编程入门 行业动态 更新时间:2024-10-18 01:41:57

使用MybatisPlus<a href=https://www.elefans.com/category/jswz/34/1771188.html style=报错,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 SQL:INSERT 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 objec

本文发布于:2024-02-10 21:47:49,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1677472.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:报错   generated   Error   MybatisPlus   key

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!