MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException 修改错误

15 篇文章 0 订阅

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.exceptions.PersistenceException:

### The error occurred while setting parameters
### SQL: update user where id = ?
### Cause:  SQLParserException: ERROR ## get sqlparser result from cache has an error:

记录一个测试环境的bug 错误大概长这样,由于有的字段不方便放出来做了调整。

大概场景是测试,测试修改方法的时候报的一个错。修改方法mapper文件是if判断,如果不为null就修改, mapper xml 的if 动态sql 应该都知道把

但是由于测试人员没有传任何修改值,直接调用了这个方法。导致发出去的sql大概长这样

update user where id = ?

sql 中间缺少了要修改的字段以及值 set username = '张三' 之类的成了一个畸形sql

我想到 的两个修复方法,

一个入过此次修改没有任何要变更的值,就不调用修改方法发起sql

一个是使用原行确定存在的一个值发起sql 就不判断对象有没有值了。就是确保发起的sql 一定有一个字段是有值的,在原来的记录里面拿一个不为空的字段。如果这个字段有被修改就使用修改的值,如果没有被修改就使用数据库的值。确保sql的正确性。OK

一般表都会有更新时间 创建时间,只要在发起sql时传入更新时间其实sql就不会有这个问题。

我们的表的更新时间是数据库层面自动填充,所以才会出现这个问题。可能出现这种问题的还是少部分人吧

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Silence丶你的名字

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值