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

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

 

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 乱肉伦孕小说在线阅读 | 手机看日韩片 | 99视频在线看观免费 | 91全国探花精品正在播放 | 欧美激情一区二区亚洲专区 | 日本动漫的18涩涩视频 | 天天射天天干天天舔 | 欧美日韩视频在线 | 欧美x性 | 国产va精品免费观看 | 日本在线国产 | 看全色黄大色黄大片免责看 | 亚洲欧美h | 成人精品视频在线观看 | 亚洲国产精品高清在线一区 | 久久久久久午夜精品 | 日本妇丰满乱xxxxⅹ视频 | 国产成人综合在线 | 深夜一级毛片 | 一级a性色生活片毛片 | 在线精品亚洲欧洲第一页 | 亚洲日本一区二区三区高清在线 | 一色综合 | 成人精品视频在线观看播放 | 美女被啪全免视频软件 | 免费午夜剧场 | 国产在线播放一区二区 | 日本欧美一区二区三区在线观看 | 91看片淫黄大片欧美看国产片 | 国产成人无精品久久久 | 最近2019年中文字幕一页 | 成人在线视频免费观看 | 男女羞羞免费视频 | 久久久国产精品免费 | 免费视频黄 | 91av导航| 日本在线一区二区 | 久久精品国产亚洲高清 | 免费观看黄色视屏 | 激情影院a| 免费看欧美一级特黄a大片一 |