调用SqlSession的各种方法报错排查(Error xxx . Cause: xxx)

当调用SqlSession的方法,偶尔出现一些Error xxx . Cause: xxx,这种异常信息难以看出来是哪里引起的问题,而SqlSession有三个实现类(SqlSessionTemplate,SqlSessionManager,DefaultSqlSession);

下面会展示这三个类的底层代码封装的异常信息,以便于我们排查,(当出现下列报错,大多数是配置问题)

具体排查问题的过程可以参照:
mybatis批量更新(BATCH)报空指针异常(Error committing transaction. Cause:NullPointerException)-CSDN博客

大部分都进入的默认的实现类DefaultSqlSession,其中所有报错信息如下:

1.  Expected one result (or null) to be returned by selectOne(), but found:
对应方法->selectOne(String statement, Object parameter)

2.  Error querying database. Cause:
对应方法->selectCursor(String statement, Object parameter, RowBounds rowBounds);

对应方法->selectList(String statement, Object parameter, RowBounds rowBounds);

对应方法->select(String statement, Object parameter, RowBounds rowBounds, ResultHandler handler);

3. Error updating database. Cause:
对应方法->update(String statement, Object parameter)

4. Error committing transaction. Cause:
对应方法->commit(boolean force)

5. Error rolling back transaction. Cause:

对应方法->rollback(boolean force)

6. Error flushing statements. Cause:

对应方法->flushStatements()

7. Error closing cursor. Cause:

对应方法->closeCursors()

8. Error getting a new connection. Cause:

对应方法->getConnection()

其余两个类没有罗列出来,大家可以自己进入类中搜索一下~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值