如果現在我們要刪除person表中id為5的記錄,但是在PersonServiceBean類的delete()方法中,人為地拋出一個運行時異常,如下
~~~
public void delete(Integer personid) {
jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
new int[]{java.sql.Types.INTEGER});
throw new RuntimeException("運行期異常");
}
~~~
此時測試PersonServiceTest類中的delete()方法:
~~~
@Test
public void delete() {
personService.delete(5);
}
~~~
會發現Eclipse控制臺打印出一個異常,立馬查看person表,發現id為5的記錄沒有刪除掉,這就說明了Spring容器默認情況下對運行時異常,它會進行事務的回滾。
如果在PersonServiceBean類的delete()方法中,人為地拋出一個檢查時異常,如下:
~~~
public void delete(Integer personid) throws Exception {
jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
new int[]{java.sql.Types.INTEGER});
throw new Exception("檢查時異常");
}
~~~
為了不報錯,我們還須將PersonService接口中的delete()方法簽名修改為:
~~~
/**
* 刪除指定id的person
*/
public void delete(Integer personid) throws Exception;
~~~
此時測試PersonServiceTest類中的delete()方法
~~~
@Test
public void delete() {
try {
personService.delete(5);
} catch (Exception e) {
e.printStackTrace();
}
}
~~~
會發現控制臺打印出一個異常,立馬查看person表,發現id為5的記錄被刪除掉,這就說明了如果Spring容器碰到的是用戶異常,如檢查時異常(checked exception),這時事務就不會回滾。
當然我們也可改變這種規則:
* 當Spring容器碰到用戶異常——如檢查時異常(checked exception)時,讓事務回滾。
那到底該怎么辦呢?此時就需要用到事務的rollbackFor屬性了。我們將PersonServiceBean類的delete()方法修改為:
~~~
@Transactional(rollbackFor=Exception.class)
public void delete(Integer personid) throws Exception {
jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
new int[]{java.sql.Types.INTEGER});
throw new Exception("檢查時異常");
}
~~~
此時測試PersonServiceTest類中的delete()方法:
~~~
@Test
public void delete() {
try {
personService.delete(4);
} catch (Exception e) {
e.printStackTrace();
}
}
~~~
會發現控制臺打印出一個異常,立馬查看person表,發現id為4的記錄沒有被刪除掉。
* 當Spring容器碰到運行時異常時,不讓它進行事務的回滾,而是提交事務。
那到底該怎么辦呢?此時就需要用到事務的rollbackFor屬性了。我們將PersonServiceBean類的delete()方法修改為:
~~~
@Transactional(noRollbackFor=RuntimeException.class)
public void delete(Integer personid) throws Exception {
jdbcTemplate.update("delete from person where id=?", new Object[]{personid},
new int[]{java.sql.Types.INTEGER});
throw new RuntimeException("運行期異常");
}
~~~
此時測試PersonServiceTest類中的delete()方法, 會發現Eclipse控制臺打印出一個異常,立馬查看person表,發現id為4的記錄已經被刪除掉了。
- 基礎
- 編譯和安裝
- scanner類(鍵盤錄入)
- Random類(隨機數)
- 數組
- 方法
- 類
- ArrayList集合
- char與int
- eclipse
- IDEA
- 變量與常量
- 常用API
- String,StringBuffer,StringBuilder
- 正則,Date,DateFormat,Calendar
- 包裝類,System,Math,Arrays,BigInteger,BigDecimal
- 集合,迭代器,增強for,泛型
- List,set,判斷集合唯一
- map,Entry,HashMap,Collections
- 異常
- IO
- File
- 遞歸
- 字節流
- 字符流
- IO流分類
- 轉換流
- 緩沖流
- 流的操作規律
- properties
- 序列化流與反序列化流
- 打印流
- commons-IO
- IO流總結
- 多線程
- 線程池
- 線程安全
- 線程同步
- 死鎖
- lock接口
- ThreadLoad
- 等待喚醒機制
- 線程狀態
- jdbc
- DBUtils
- 連接池DBCP
- c3p0連接池
- 網絡編程
- 多線程socket上傳圖片
- 反射
- xml
- 設計模式
- 裝飾器模式
- web service
- tomcat
- Servlet
- response
- request
- session和cookie
- JSP
- EL
- JSTL
- 事務
- 監聽器Listener
- 過濾器Filter
- json
- linux安裝軟件
- 反射詳解
- 類加載器和注解
- 動態代理
- jedis
- Hibernate
- 簡介
- 創建映射文件
- Hibernate核心配置文件
- 事務和增刪改查
- HibernateUtils
- 持久化對象的三種狀態
- 檢索方式
- query
- Criteria
- SQLQuery
- 持久化類
- 主鍵生成策略
- 緩存
- 事務管理
- 關系映射
- 注解
- 優化
- struts2
- 搭建
- 配置詳解
- Action
- 結果跳轉方式
- 訪問ServletAPI方式
- 如何獲得參數
- OGNL表達式
- valueStack 值棧
- Interceptor攔截器
- spring
- 導包
- IOC和DI
- Bean獲取與實例化
- Bean屬性注入
- spring注解
- 注解分層
- junit整合
- aop
- 動態代理實現
- cglib代理實現
- aop名詞
- spring的aop
- aop-xml詳解
- aop-注解詳解
- 代理方式選擇
- jdbcTemplate
- spring事務管理
- 回滾注意
- 事務傳播屬性
- MyBatis
- MyBatis簡介
- 入門程序
- 與jdbc hibernate不同
- 原始Dao開發
- Mapper動態代理方式
- SqlMapConfig.xml配置文件
- 輸入參數pojo包裝類
- resultMap
- 動態sql
- 一對一關聯
- 一對多
- 整合spring
- 逆向工程
- maven
- maven簡介
- 倉庫
- maven目錄結構
- maven常用命令
- 生命周期
- eclipse中maven插件
- 入門程序
- 整合struct
- 依賴范圍
- 添加插件
- idea配置
- jar包沖突
- 分模塊開發
- 構建可執行的jar包(包含依賴jar包)
- springMVC
- 處理流程
- java面試
- java版本升級
- java1-8版本變更
- java9新特性
- 鎖
- java資料
- idea
- jdk版本切換
- log4j
- 入門實例
- 基本使用方法
- Web中使用Log4j
- spring中使用log4j
- java代碼優化