当调用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()
其余两个类没有罗列出来,大家可以自己进入类中搜索一下~