偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

iBATIS事務處理淺析

開發(fā) 后端
iBATIS事務處理是什么內容呢?你對它是不是很熟悉呢?那么本文將會給你介紹iBATIS事務處理相關的信息,希望對你有所幫助。

iBATIS事務處理這部分是和Dao緊密相聯的。

我們在使用Dao時,如以下代碼,先插入新記錄,再進行更新:

  1. personDao.insertPerson (person); // Starts transaction  
  2. person.setLastName("Begin");  
  3. personDao.updatePerson (person); // Starts a new transaction 

因為沒有顯式地啟動事務,iBatis會認為這是兩次事務,分別從連接池中取兩次Connectio。

我們所寫的Dao子類(繼承自com.ibatis.dao.client.template.SqlMapDaoTemplate)的每一個Dao方法已經默認為一個事務(通過動態(tài)代理)。

而在業(yè)務層,應該有一個類來統(tǒng)管Dao子類的事務,iBatis是通過DaoManager類來作這件事的,如下:

DaoManager provides access to all DAOs it manages and also allows transactions to be committed and ended (possibly rolled back)

眾Dao子類由DaoManager產生,如:

  1. DaoManager daoManager = DaoManagerBuilder.buildDaoManager(reader);  
  2.  
  3. UserDao userDao = (UserDao) daoManager.getDao(UserDao.class); 

UserDao是用戶自己定義的接口,獲得的其實是在dao.xml中指定的相對應的 SqlMapDao實現類,從而實現了松藕合。在良好的分層設計中,

iBATIS事務處理之業(yè)務層(service包)只需要知道Dao接口,而不去關心其具體怎么實現。

如果顯式地聲明事務處理語句,如下:

  1. try {  
  2. daoManager.startTransaction();  
  3. personDao.insertPerson (person);   
  4. person.setLastName("Begin");  
  5. personDao.updatePerson(person);   
  6. otherDao.doSomething(other);  
  7. ...  
  8. daoManager.commitTransaction();  
  9. finally {  
  10. daoManager.endTransaction();  

這樣就保持了原子性,整體為一個事務,要么全部執(zhí)行成功,否則回滾。

現在唯一的問題就是,dao層的事務是否已經放棄,否則產生事務嵌套問題對性能會有影響

當然,iBatis 完全可以這么做:建一個聲明式接口:IService,再使用動態(tài)代理,將用戶自己的Serivce子類通過動態(tài)代理自動包上事務處理的代碼,默 認每一個業(yè)務方法為一個事務。

大師的心如果能輕易揣測,就是不大師了:),估計大師認為這樣屬于過度設計,他認為把這種靈活性交給用戶是合適的,相當多的service 方法只調用一個Dao方法,例如CRUD操作。

再補充一下,iBatis中對事務的處理是可配置的,最常用的Type是"JDBC",也可以聲明為"JTA"或"EXTERNAL".

iBATIS事務處理相關的介紹就到這里,是不是對iBATIS事務處理有了一定的了解呢?

【編輯推薦】

  1. iBATIS操作Blob與Clob淺析
  2. iBATIS讀寫CLOB數據淺析
  3. iBATIS操作CLOB字段實戰(zhàn)淺析
  4. iBATIS for Eclipse設置淺析
  5. iBATIS的自動代碼生成工具Abator在Eclipse的應用
責任編輯:仲衡 來源: 王朝網絡
相關推薦

2009-09-14 19:55:03

LINQ事務處理

2011-04-27 15:55:16

2009-07-09 18:15:42

JDBC事務處理

2010-01-04 13:06:50

ADO.NET事務

2009-11-13 17:01:07

ADO.NET事務處理

2014-01-22 13:37:53

2010-04-13 15:44:00

Oracle與SqlS

2022-06-22 05:42:32

數據庫事務處理分析查詢

2009-07-20 18:00:16

iBATIS DAO事

2017-04-10 13:30:47

Redis數據庫命令

2011-04-27 16:09:48

SQL ServerSSIS

2010-05-17 14:59:05

MySQL事務處理

2009-11-04 15:05:45

ADO.NET事務

2022-06-13 10:42:21

分布式事務數據庫

2009-04-15 17:03:15

OracleSQL Server事務處理

2011-05-18 08:34:45

javaJDBC

2009-06-16 11:42:00

JDBC事務處理JavaBean

2011-03-15 10:22:42

SQL Server 聯機事務處理

2014-02-11 09:07:31

2010-01-13 14:13:24

VB.NET事務處理
點贊
收藏

51CTO技術棧公眾號