<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    我的java天地

    Spring事務管理

    在學習spring事務管理時,我忍不住要問,spring為什么進行事務管理,spring怎么進行的事務管理?
    首先,為什么要進行事務,接下來說說spring是怎樣進行事務管理的.
    Spring事務策略
    Spring事務策略,也就是spring事務管理的實現方式.它有一個統一的抽象是由實現下面這個接口完成的.
    org.springframework.transaction.PlatformTransactionManager
    此接口的內容如下:
    Public interface PlatformTransactionManager()...{TransactionStatue getTransaction(TransactionDefinition definition) throws TransactionException;Void commit(TransactionStatus status) throws TransactionException;Void rollback(TransactionStatus status) throws TransactionException;}

    不管是聲明式的還是編程式的事務管理都需要此抽象來完成.
    解釋一下這個接口,這樣可以更好的理解spring的事務控制的原理.
    getTransaction()根據類型為TransactionDefinition的參數返回一個TransactionStatus對象.返回的TransactionStatus對象可能代表一個新的或已經存在的事務(如果在當前調用堆棧有一個符合條件的事務).如同J2EE事務上下文,一個TransactionStatus也是和執行的線程關聯的.
    同時,在框架中還存在TransactionDefinition接口,即上邊的參數類型.此接口指定了事務隔離程度、事務傳播、事務超時、只讀狀態。
    另外,還有TransactionStatus接口。這個接口為處理事務提供簡單的控制事務執行和查詢事務狀態的方法。

    ② 兩種事務管理方式:編程式、聲明式。
    Spring提供兩種方式的編程式事務管理,分別是:使用TransactionTemplate和直接使用PlatformTransactionManager。
    ⅰ. TransactionTempale采用和其他Spring模板,如JdbcTempalte和HibernateTemplate一樣的方法。它使用回調方法,把應用程序從處理取得和釋放資源中解脫出來。如同其他模板,TransactionTemplate是線程安全的。
    代碼片段: Object result = tt.execute(new TransactionCallback()...{public Object doTransaction(TransactionStatus status)...{updateOperation();return resultOfUpdateOperation();}});

    使用TransactionCallback()可以返回一個值。
    如果使用TransactionCallbackWithoutResult則沒有返回值。
    ⅱ. 也可以使用PlatformTransactionManager直接管理事務。簡單地通過一個bean引用給你的bean傳遞一個你使用的PlatformTransaction對象。然后,使用TransactionDefinition和TransactionStatus對象就可以發起、回滾、提交事務。
    如下片段: DefaultTransactionDefinition? ?def=
    new DefaultTransactionDefinition();? ?? ?? ?? ?? ?? ? //new 一個事務
    def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRED); //初始化事務,參數定義事務的傳播類型;
    TransactionStatus??status = transactionManager.getTransaction(def);? ?? ?? ?? ?? ?? ???//獲得事務狀態
    try...{……………..transactionManager.commit(status); //提交事務;
    }catch(…..)...{transactionManager.rollback(status); //回滾事務;
    }

    Spring也提供聲明式事務管理。這是通過AOP實現的。
    大多數Spring用戶選擇聲明式事務管理,這是最少影響應用代碼的選擇,因而這是和非侵入性的輕量級容器的觀念是一致的。
    ① 通常通過TransactionProxyFactoryBean設置Spring事務代理。需要一個目標對象包裝在事務代理中。這個目標對象一般是一個普通Javabean。當我們定義TransactionProxyFactoryBean時,必須提供一個相關的PlatformTransactionManager的引用和事務屬性。事務屬性含有事務定義。例如: <bean id="transactionService"class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
    <property name="transactionManager">
    <ref? ?local="transactionManager"/>
    </property>
    <property??name="target">
    <ref??local="transactionServiceControl"/>
    </property>
    <property??name="transactionAttributes">
    <props>
    <prop key=”insert*>PROPAGATION_REQUIRED,-MyCheckedException</prop>
    <prop key=”update*>PROPAGATION_REQUIRED</prop>
    <prop key=*>PROPAGATION_REQUIRED,readOnly</prop>
    </props>
    </property>
    </bean>

    事務代理會實現目標對象的接口:這里是屬性名是target的引用。id是transactionServiceControl。(●使用CGLIB也可以實現具體類的代理。只要設置proxyTargetClass屬性為true即可。如果目標對象沒有實現任何接口,這將自動設置該屬性為true。通常,我們希望面向接口編程。) ●使用proxyInterfaces屬性來限定事務代理來代理指定接口也是可以。 ●也可以通過從org.springframework.aop.framework.ProxyConfig繼承或所有AOP代理工廠共享的屬性來定制TransactionProxyFactoryBean行為。
    然后,說說屬性名是transactionAttributes意義:
    這里的transactionAttributes屬性是定義在org.springframework.transaction.interceptor.NameMathTransactionAttributeSource中的屬性格式設置。這個包括通配符的方法名稱映射是很直觀的,如”insert*”。注意insert*的映射的值包括回滾規則。”-MyCheckException”指定如果方法拋出MyCheckException或它的子類,事務會自動回滾。可以用逗號分隔多個回滾規則。“-”前綴強制回滾,“+”前綴指定提交(這允許即使拋出unchecked異常時也可以提交事務)。“PROPAGATION_REQUIRED”指定事務傳播范圍。
    TransactionProxyFactoryBean允許你通過“preInterceptors”和“postInterceptors”屬性設置前或后的攔截操作。可以設置任意數量的前和后通過,它們的類型可以是Advistor(切入點),MethodInterceptor或被當前Spring配置支持的通知類型。例如:ThrowAdvice,AfterReturningAdvice或BeforeAdvice。這些通知必須支持實例共享模式。如果你需要高級AOP特性操作事務,通過org.springframework.aop.framework.ProxyFactoryBean,而不是TransactionProxyFactory實用代理創建者。
    ② 另一種聲明方式:BeanNameAutoProxyCreator
    使用TransactionProxyFactoryBean當事務代理包裝對象,你可以完全控制代理。如果需要用一致方式包裝大量bean。使用一個BeanFactoryPostProcessor的一個實現,BeanNameAutoProxyCreator,可以提供另外一種方法。(Spring中,一旦ApplicationContext讀完它的初始化信息,它將初始化所有實現BeanPostProcessor接口的bean,并且讓它們后處理ApplicationContext中所有其他的bean。所以使用這種機制,正確配置的BeanNameAutoProxyCreator可以用來后處理所有ApplicationContext中所有其他的bean),并且把它們用事務代理包裝起來。真正生成的事務代理和使用TransactionProxyFactoryBean生成的基本一致。
    最后,總結一下Spring的優點:
    ★ 為不同的事務API提供一致的編程模型,如JTA、JDBC、Hibernate、iBATIS數據庫層JDO
    ★ 提供比大多數事務API更簡單的、易于使用的編程式事務管理API
    ★ 整合Spring數據訪問抽象
    ★ 支持Spring聲明式事務管理

    posted on 2009-03-21 03:17 tobyxiong 閱讀(225) 評論(0)  編輯  收藏 所屬分類: java

    <2009年3月>
    22232425262728
    1234567
    891011121314
    15161718192021
    22232425262728
    2930311234

    導航

    統計

    常用鏈接

    留言簿(3)

    隨筆分類(144)

    隨筆檔案(157)

    相冊

    最新隨筆

    搜索

    積分與排名

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲国产精品久久66| 成人免费无码大片A毛片抽搐色欲| 亚洲乱码国产乱码精华| 日日摸日日碰夜夜爽亚洲| 免费中文字幕视频| 久久精品免费观看| 日韩精品无码区免费专区 | 亚洲国产婷婷六月丁香| 亚洲字幕在线观看| 国产AV日韩A∨亚洲AV电影| 91av视频免费在线观看| 国产大片51精品免费观看| 亚洲一区二区三区影院 | 亚洲日韩在线第一页| 亚洲高清无在码在线无弹窗| 精品国产亚洲AV麻豆| 免费成人午夜视频| 亚洲成a人片在线观| 国产精品视频免费一区二区| 黄色网页免费观看| 精品免费国产一区二区三区| 亚洲白色白色永久观看| 久久免费视频精品| 亚洲美女在线国产| 亚洲国产综合AV在线观看| 1000部无遮挡拍拍拍免费视频观看| 亚洲视频在线免费| 香蕉免费一区二区三区| 亚洲中文字幕无码日韩| 日本激情猛烈在线看免费观看| 亚洲产国偷V产偷V自拍色戒| 黄床大片30分钟免费看| 亚洲AV永久无码精品成人| a级毛片在线免费看| 亚洲第一视频在线观看免费| 亚洲国产精品99久久久久久 | 亚洲国产另类久久久精品黑人 | 亚洲熟妇久久精品| 最近中文字幕mv免费高清视频7 | 免费无码黄网站在线观看| 亚洲天堂免费在线视频|