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

iBATIS DAO事務(wù)淺析

開(kāi)發(fā) 后端
iBATIS DAO事務(wù)都有些什么內(nèi)容呢,這篇文章將會(huì)給你介紹相關(guān)的iBATIS DAO事務(wù)信息。

iBATIS DAO事務(wù)的理解要從iBATIS DAO 框架開(kāi)始,它提供了事務(wù)管理模塊。而這個(gè)事務(wù)管理可以應(yīng)用到很多場(chǎng)合,包括JDBC、Hibernate、JTA、SQLMAP等。

下面以最簡(jiǎn)單的JDBC來(lái)分析一下其如何實(shí)現(xiàn)iBATIS DAO事務(wù)管理。

首先來(lái)看一段代碼:

  1. public class OrderService {  
  2.  
  3. private DaoManager daoManager;  
  4.  
  5. private OrderDao orderDao;  
  6.  
  7. public OrderService() {  
  8. daoManager = DaoConfig.getDaoManager();  
  9. orderDao = (OrderDao) daoManager.getDao(OrderDao.class);  
  10. }  
  11.  
  12. public void method() {  
  13. try {  
  14. //a separate transaction  
  15. orderDao.method1(); //***個(gè)事務(wù)  
  16.  
  17. daoManager.startTransaction(); //開(kāi)始第二個(gè)事務(wù)  
  18.  
  19. orderDao.method1();  
  20. orderDao.method2();  
  21.  
  22. daoManager.commitTransaction();//提交第二個(gè)事務(wù)  
  23. finally {  
  24. daoManager.endTransaction();  
  25. }  
  26. }  

在method()方法里有著兩個(gè)事務(wù),如果在方法里不顯式的調(diào)用daoManager.startTransaction(),則每個(gè)DAO的一次方法調(diào)用就是一個(gè)獨(dú)立的事務(wù)。

iBATIS DAO事務(wù),有兩個(gè)核心接口DaoTransactionManager和DaoTransaction

對(duì)應(yīng)著不同的數(shù)據(jù)庫(kù)持久層實(shí)現(xiàn),兩個(gè)接口分別對(duì)應(yīng)著不同實(shí)現(xiàn)

查看iBATIS 代碼,可以發(fā)現(xiàn)這些manager實(shí)現(xiàn)事務(wù),就是調(diào)用事務(wù)源的事務(wù)操作方法

  1. JdbcDaoTransactionManager  
  2. public void commitTransaction(DaoTransaction trans) {  
  3. ((JdbcDaoTransaction) trans).commit();  
  4. }  
  5.  JdbcDaoTransaction  
  6. public JdbcDaoTransaction(DataSource dataSource) {  
  7. try {  
  8. connection = dataSource.getConnection();  
  9. if (connection == null) {  
  10. throw new DaoException("Could not start transaction.Cause: The DataSource returned a null connection.");  
  11. }  
  12. if (connection.getAutoCommit()) {  
  13. connection.setAutoCommit(false);  
  14. }  
  15. if (connectionLog.isDebugEnabled()) {  
  16. connection = ConnectionLogProxy.newInstance(connection);  
  17. }  
  18. catch (SQLException e) {  
  19. throw new DaoException("Error starting JDBC transaction.Cause: " + e);  
  20. }  
  21. }  
  22.  
  23. public void commit() {  
  24. try {  
  25. try {  
  26. connection.commit();  
  27. finally {  
  28. connection.close();  
  29. }  
  30. catch (SQLException e) {  
  31. throw new DaoException("Error committing JDBC transaction.Cause: " + e);  
  32. }  

那么DaoTransactionManager以什么依據(jù)處理事務(wù)呢?DaoTransactionState看看DaoTransactionState的代碼,非常簡(jiǎn)單,四個(gè)常量來(lái)表示事務(wù)處于的不同的狀態(tài)

public static final DaoTransactionState ACTIVE = new DaoTransactionState();

public static final DaoTransactionState INACTIVE = new DaoTransactionState();

public static final DaoTransactionState COMMITTED = new DaoTransactionState();

public static final DaoTransactionState ROLLEDBACK = new DaoTransactionState();

那么實(shí)際程序中是如何控制事務(wù)的呢

在***段代碼中,我們是這樣取得DAO

orderDao = (OrderDao) daoManager.getDao(OrderDao.class);

實(shí)際daoManager返回的并不是orderDao的具體實(shí)現(xiàn)類,它返回的DaoProxy

DaoProxy

  1. public Object invoke(Object proxy, Method method, Object[] args)  
  2. throws Throwable {  
  3. Object result = null;  
  4. if (PASSTHROUGH_METHODS.contains(method.getName())) {  
  5. try {  
  6. result = method.invoke(daoImpl.getDaoInstance(), args);  
  7. catch (Throwable t) {  
  8. throw ClassInfo.unwrapThrowable(t);  
  9. }  
  10. else {  
  11. StandardDaoManager daoManager = daoImpl.getDaoManager();  
  12. DaoContext context = daoImpl.getDaoContext();  
  13.  
  14. if (daoManager.isExplicitTransaction()) {  
  15. // Just start the transaction (explicit)  
  16. try {  
  17. context.startTransaction();  
  18. result = method.invoke(daoImpl.getDaoInstance(), args);  
  19. catch (Throwable t) {  
  20. throw ClassInfo.unwrapThrowable(t);  
  21. }  
  22. else {  
  23. // Start, commit and end the transaction (autocommit)  
  24. try {  
  25. context.startTransaction();  
  26. result = method.invoke(daoImpl.getDaoInstance(), args);  
  27. context.commitTransaction();  
  28. catch (Throwable t) {  
  29. throw ClassInfo.unwrapThrowable(t);  
  30. finally {  
  31. context.endTransaction();  
  32. }  
  33. }  
  34.  
  35. }  
  36. return result;  

看到這段代碼就非常清楚了,每調(diào)用DAO的一次方法時(shí),如果不顯式的調(diào)用daoManager.startTransaction(),就會(huì)成為單獨(dú)的一個(gè)iBATIS DAO事務(wù)。再看看iBATIS為我們提供的摸板JdbcDaoTemplate

  1. protected Connection getConnection() {  
  2. DaoTransaction trans = daoManager.getTransaction(this);  
  3. if (!(trans instanceof ConnectionDaoTransaction)) {  
  4. throw new DaoException("The DAO manager of type " + daoManager.getClass().getName() +  
  5. " cannot supply a JDBC Connection for this template, and is therefore not" +  
  6. "supported by JdbcDaoTemplate.");  
  7. }  
  8. return ((ConnectionDaoTransaction) trans).getConnection();  

iBATIS控制多個(gè)DAO的事務(wù)實(shí)際是讓這些DAO共用了一個(gè)DaoTransaction(ThreadLocal),一個(gè)Connection

這里是一個(gè)事務(wù)源的情況,如果多個(gè)事務(wù)源之間要完成全局事務(wù),還是老老實(shí)實(shí)用分布式事務(wù)管理服務(wù)吧(jta)。

iBATIS DAO事務(wù)的相關(guān)信息就向你介紹到這里,之后的文章里我們還會(huì)提及的,請(qǐng)關(guān)注。

【編輯推薦】

  1. Struts2.0+Springframework2.5+ibatis2.3***整合實(shí)例
  2. Struts2.0+ibatis2.3***整合實(shí)例之映射淺析
  3. Struts2.0+ibatis2.3整合實(shí)例實(shí)現(xiàn)服務(wù)層及Struts
  4. Struts2.0+ibatis2.3整合實(shí)例實(shí)現(xiàn)UI層淺析
  5. iBATIS入門程序六大步詳解
責(zé)任編輯:仲衡 來(lái)源: CSDN博客
相關(guān)推薦

2009-07-16 09:14:26

iBATIS DAO

2009-07-21 11:17:46

iBATISDAO的配置

2009-07-20 14:56:18

iBATIS.NET動(dòng)態(tài)選擇DAO

2009-07-15 17:41:55

iBATIS事務(wù)處理

2009-07-17 14:03:34

ibatis DAO事務(wù)管理

2009-07-16 17:01:32

ibatis dao

2009-07-21 11:12:00

iBATIS配置

2009-07-16 16:27:33

ibatis DAO

2009-07-21 13:08:08

iBATIS DAO

2009-07-17 10:32:45

iBATIS MapB

2009-07-22 10:03:11

iBATIS Resu

2009-07-15 17:19:31

iBATIS Ecli

2009-07-22 10:42:59

iBATIS Cach

2009-07-15 17:58:07

iBATIS 動(dòng)態(tài)映射

2009-07-16 10:23:30

iBATIS工作原理

2009-07-22 13:32:43

iBATIS DAO

2009-07-16 13:08:09

iBATIS快速創(chuàng)建應(yīng)

2009-07-22 15:21:00

iBATIS SQLM

2009-07-15 16:42:03

iBATIS讀寫CLO

2009-07-17 17:05:44

iBATIS緩存cacheModel
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)