Mybatis執行update失敗的解決
Mybatis執行update失敗
今天在進行分佈式重構項目的時候碰到一個問題,在執行sql的時候隻有update不能成功,其他語句都可以正常執行,報錯如下: 版本:org.mybatis:mybatis:3.4.5
接口
@UpdateProvider(type = ManagerProvider.class, method = "updateManager") int updateManager(Manager manager) throws Exception;
報錯信息
Loading XML bean definitions from class path resource [org/springframework/jdbc/support/sql-error-codes.xml]
SQLErrorCodes loaded: [DB2, Derby, H2, HSQL, Informix, MS-SQL, MySQL, Oracle, PostgreSQL, Sybase, Hana]
org.springframework.jdbc.UncategorizedSQLException: Error getting generated key or setting result to parameter object. Cause: java.sql.SQLException: 不允許的操作;uncategorized SQLException for SQL []; SQL state [99999]; error code [17090]; 不允許的操作; nested exception is java.sql.SQLException: 不允許的操作
原因
由於mybatis在執行insert和update的時候都默認生成key,然後註入,所以在執行update的時候會報錯。
解決辦法
在接口上增加註解 @Options(useGeneratedKeys = false),不讓mybatis自動註入key,問題解決。
@UpdateProvider(type = ManagerProvider.class, method = "updateManager") @Options() // @Options(useGeneratedKeys = false) int updateManager(Manager manager) throws Exception;
最後說明一點,版本:org.mybatis:mybatis:3.4.4這個版本沒有此類問題。
Mybatis插入(更新)失敗 卻不報錯
問題描述
mybatis進行數據插入或更新操作,方法成功執行,數據庫中卻不存在新數據,原本代碼如下:
@Test public void test7() throws IOException { SqlSessionFactory sqlSessionFactory = getSqlSessionFactory(); SqlSession sqlSession = sqlSessionFactory.openSession(); EmployeeMapperDynamicSql mapper = sqlSession.getMapper(EmployeeMapperDynamicSql.class); Employee employee = new Employee(null,"gfdhg","[email protected]","female",null); mapper.addEmps(Collections.singletonList(employee)); sqlSession.close(); }
解決方案
在插入或更新語句後,增添commit,代碼如下:
@Test public void test7() throws IOException { SqlSessionFactory sqlSessionFactory = getSqlSessionFactory(); SqlSession sqlSession = sqlSessionFactory.openSession(); EmployeeMapperDynamicSql mapper = sqlSession.getMapper(EmployeeMapperDynamicSql.class); Employee employee = new Employee(null,"gfdhg","[email protected]","female",null); mapper.addEmps(Collections.singletonList(employee)); /*添加commit*/ sqlSession.commit(); sqlSession.close(); }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- Mybatis 一級緩存和二級緩存原理區別
- 一篇文章帶你學習JAVA MyBatis底層原理
- 初次體驗MyBatis的註意事項
- MyBatis基本實現過程
- Java Mybatis框架增刪查改與核心配置詳解流程與用法