大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 MyBatis事務回滾例子

MyBatis事務回滾例子

更新時間:2022-03-23 10:10:32 來源:動力節點 瀏覽2456次

mybatis批量操作中,插入多條數據時,設置回滾,但是之前的幾條還是插入的。嘗試后

問題是:

官網api上的openSession(false)可以回滾,但是用session查看還是可以的。獲取連接()。獲取自動提交 ()

解決方案:

將 DataSource 配置更改為 AutoCommit (false)

設置setAutoCommit(false)為conn,用conn提交和回滾

例子:

SqlSession session = sqlSessionFactory.openSession(false);
  Connection conn = session.getConnection();
  conn.setAutoCommit(false);
  try {
   UserMapper mapper = session.getMapper(UserMapper.class);
   for (String name : names) {
     // Various operations 
    User user = new User();
    user.setName(name);
    // Insert, require rollback 
    mapper.insert(user);
   }
   conn.commit();
  } catch (Exception e) {
   // There are repeated rollbacks 
   conn.rollback();
   throw e;
  } finally {
   session.close();
  }

補充:Spring Boot + Mybatis Plus 手動觸發事務回滾

使用第一種方法(省略數據庫操作的代碼)操作Mybatis Plus的事務,如果有異常進入catch,數據庫操作不會回滾,但是會報No transaction aspect-managed TransactionStatus in scope的錯誤改為報告。修改為第二種方法可以正常管理和回滾事務

請參閱此情況的說明:

@Transactional必須觸發aop代理才能生效,所以非公有方法不執行事務,而公有方法在該類中被引用不執行事務

方法一:

@PostMapping("/save1")
public boolean action01() {
 return action00(); 
}
@PostMapping("/save2")
public boolean action02() {
 return action00(); 
}
@Transactional
private boolean action00() {
 String result = true;
 try {
  System.out.println(1/0);
 } catch (Exception e) {
  TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  result = false;
 }
 return result;
}

方法二:

@PostMapping("/save1")
@Transactional
public boolean action01() {
 boolean result = action00();
 if (!result){
  TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
 }
 return result; 
} 
@PostMapping("/save2")
@Transactional
public boolean action02() {
 boolean result = action00();
 if (!result){
  TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
 }
 return result; 
}  
private boolean action00() {
 String result = true;
 try {
  System.out.println(1/0);
 } catch (Exception e) {
  result = false;
 }
 return result;
}

 

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 中文字幕精品一区二区三区视频 | 亚洲成人7777 | 亚洲欧美婷婷 | 天堂日韩| 久草中文视频 | 四虎综合九九色九九综合色 | 久久国产精彩视频 | 一级特黄性色生活片 | 国产成人亚洲毛片 | 四虎国产成人永久精品免费 | 亚洲成人伦理 | 免费 黄 色 人成 视频 | 色综合久久最新中文字幕 | 欧美激情免费观看 | 天天添天天操 | 日韩性生活视频 | 欧美三区在线 | 日韩久久中文字幕 | 国产三级做爰在线播放最爱 | 五月天激情婷婷 | 欧美日韩国产最新一区二区 | 欧美香蕉爽爽人人爽观看猫咪 | 99热这里只有精品88 | 久久久综合香蕉尹人综合网 | 欧美性天天影院 | 久久亚洲国产午夜精品理论片 | 欧洲做视频在线观看 | 九月婷婷天天澡天天添天天爽 | 四虎国产| 国产成人精品高清在线观看99 | 国产成人久久 | 久草狼人| 亚洲国产成人超福利久久精品 | ww亚洲ww亚在线观看 | 四虎sihu新版影院亚洲精品 | 久热在线视频精品网站 | 国内精品久久久久久不卡影院 | 日韩精品在线视频观看 | 韩国高清乱理伦片中文 | 久久亚洲欧美成人精品 | 九九热这里都是精品 |