大战熟女丰满人妻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;
}

 

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

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 欧美成人猛男性色生活 | 国产精品一区牛牛影视 | 久久久久久青草大香综合精品 | 天天干夜啪 | 国产成人精品在线 | 色综合色狠狠天天久久婷婷基地 | 12一14周岁毛片免费网站 | 在线a亚洲视频播放在线观看 | 国产成人综合高清在线观看 | 国内精品免费视频 | 色哥网站| 国产97在线 | 亚洲 | 亚洲精品视频久久 | 欧美一级特毛片 | 国产综合亚洲精品一区 | 免费黄色毛片视频 | 午夜久久久 | 四虎免费永久观看 | 国产在线看不卡一区二区 | 日日夜夜影院 | 香蕉网久久 | 亚洲一区在线免费 | 亚洲经典在线中文字幕 | 亚洲片在线 | 99久久国内精品成人免费 | 国产高清在线精品一区二区三区 | 久久精品国产免费中文 | 福利一区在线视频 | 关婷哪一级毛片高清免费看 | 亚州欧美 | 国产真实伦视频在线视频 | 好吊妞视频一区二区 | 国产成 人 综合 亚洲绿色 | 91成人午夜在线精品 | 成人免费牛牛在线视频 | 热热涩热热狠狠色香蕉综合 | 精品久久久视频 | 精品麻豆 | 免费国产福利 | 亚洲图区综合 | 久久精品国产99久久3d动漫 |