黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

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

MyBatis事務回滾例子

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

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;
}

 

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 青草草视频在线观看 | 乱色欧美videos黑人 | 一级毛片成人午夜 | 国产亚洲欧美日本一二三本道 | 香港经典三级成人xxx | 日韩一级淫片 | 丝袜中文字幕 | 怡红院美国十次成人影院 | 97国产视频 | 好色影视 | 在线免费观看污网站 | 成人免费精品视频 | 18成禁人视频免费网站 | 一级毛片私人影院 | 欧美午夜一区二区福利视频 | 国产在线观看一区二区三区 | 免费视频成人国产精品网站 | 无遮挡一级毛片视频 | 级毛片久久久毛片精品毛片 | 男女午夜视频在线观看 | 波多野结衣在线一区二区 | 怡春院院日本一区二区久久 | 波多野结衣免费免费视频一区 | 成年男女免费视频 | 国产一区中文字幕 | 久久精品蜜芽亚洲国产a | 亚洲激情视频网站 | 国产盗摄一区二区欧美精品 | 亚洲福利 | 在线免费观看日韩视频 | 怡春院院日本一区二区久久 | 动漫无遮羞视频免费网站 | 99久久99 | 一级生活录像 | www.网站黄网站 | 在线黄色小视频 | 特级毛片永久久免费观看 | 成人男女网18免费91 | 免费视频18 | 一级特黄高清完整大片 | 91在线亚洲精品专区 |