posts - 325,  comments - 25,  trackbacks - 0

          最近碰到這個(gè)問題,在使用spring提供的JpaTemplate進(jìn)行查詢時(shí),如果數(shù)據(jù)量超過100 條,查詢效率就會(huì)明顯降低。由于開始時(shí)使用JPA內(nèi)部的雙向關(guān)聯(lián),造成各實(shí)體內(nèi)部關(guān)聯(lián)過多,從而影響所有的操作,因此懷疑是因?yàn)镴PA的關(guān)聯(lián)關(guān)系所致。但 是去掉關(guān)聯(lián)關(guān)系后的效果不顯著。 

          查找spring的相關(guān)配置,發(fā)現(xiàn)原來關(guān)于“transactionAttributes”有問題。原來的配置如下: 

          <bean id="baseTransactionProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean" 
          lazy-init="true" abstract="true"> 
          <property name="transactionManager"> 
          <ref bean="transactionManager" /> 
          </property> 
          <property name="transactionAttributes"> 
          <props> 
          <prop key="sav*">PROPAGATION_REQUIRED</prop> 
          <prop key="update*">PROPAGATION_REQUIRED</prop> 
          <prop key="delete*">PROPAGATION_REQUIRED</prop> 
          <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop> 
          <prop key="find*">PROPAGATION_REQUIRED,readOnly</prop> 
          </props> 
          </property> 
          </bean> 
          使用上述配置,在JPA打出的日志中顯示每次查詢時(shí)都要進(jìn)行更新操作,查閱相關(guān)spring 的資料后發(fā)現(xiàn)transactionAttributes的各種屬性的意義,現(xiàn)把資料分享如下: 

          PROPAGATION_REQUIRED--支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),就新建一個(gè)事務(wù)。這是最常見的選擇。 
          PROPAGATION_SUPPORTS--支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),就以非事務(wù)方式執(zhí)行。 
          PROPAGATION_MANDATORY--支持當(dāng)前事務(wù),如果當(dāng)前沒有事務(wù),就拋出異常。 
          PROPAGATION_REQUIRES_NEW--新建事務(wù),如果當(dāng)前存在事務(wù),把當(dāng)前事務(wù)掛起。 
          PROPAGATION_NOT_SUPPORTED--以非事務(wù)方式執(zhí)行操作,如果當(dāng)前存在事務(wù),就把當(dāng)前事務(wù)掛起。 
          PROPAGATION_NEVER--以非事務(wù)方式執(zhí)行,如果當(dāng)前存在事務(wù),則拋出異常。 
          PROPAGATION_NESTED--如果當(dāng)前存在事務(wù),則在嵌套事務(wù)內(nèi)執(zhí)行。如果當(dāng)前沒有事務(wù),則進(jìn)行與PROPAGATION_REQUIRED類似的操作。
          當(dāng)前所有的事務(wù)都使用“PROPAGATION_REQUIRED”屬性值,并且控制事務(wù)的操作權(quán)限為只讀,以保證查詢時(shí)不會(huì)更新數(shù)據(jù)。根據(jù)上述 定義 “PROPAGATION_REQUIRED”屬性會(huì)造成為所有的操作都創(chuàng)建事務(wù),從而會(huì)出現(xiàn)JPA的日志中查詢時(shí)也會(huì)進(jìn)行更新操作的現(xiàn)象,也就造成了效 率的低下。將所有查詢的操作改成事務(wù)類型為“PROPAGATION_NEVER”(不使用事務(wù)),則查詢效率立即提升,但是此時(shí)擔(dān)心一個(gè)問題:比如在一 個(gè)saveXXX()的方法中,如果方法內(nèi)部使用更新、查詢、再更新的操作流程,會(huì)不會(huì)造成調(diào)用查詢時(shí),由于上述配置造成的拋出異常。 

          另外,如果出現(xiàn) 

          〈prop key="myMethod"〉PROPAGATION_REQUIRED,readOnly,-Exception〈/prop〉 
          這樣的配置,其中: 

          -Exception表示有Exception拋出時(shí),事務(wù)回滾. -代表回滾+就代表提交 

          readonly 就是read only, 設(shè)置操作權(quán)限為只讀,一般用于查詢的方法,優(yōu)化作用.
          源自:http://www.aygfsteel.com/javagrass/archive/2011/08/08/355988.html
          posted on 2015-08-07 13:03 長春語林科技 閱讀(203) 評(píng)論(0)  編輯  收藏 所屬分類: spring
          <2015年8月>
          2627282930311
          2345678
          9101112131415
          16171819202122
          23242526272829
          303112345

           

          長春語林科技?xì)g迎您!

          常用鏈接

          留言簿(6)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          相冊

          收藏夾

          搜索

          •  

          最新評(píng)論

          閱讀排行榜

          評(píng)論排行榜

          主站蜘蛛池模板: 吴旗县| 岳普湖县| 高密市| 罗源县| 荥经县| 巨野县| 竹山县| 桃园市| 吉隆县| 昌江| 木兰县| 田阳县| 瓦房店市| 茶陵县| 濮阳县| 莲花县| 周口市| 邓州市| 莱芜市| 农安县| 定襄县| 宜兰市| 高州市| 闽清县| 都兰县| 夹江县| 鞍山市| 金塔县| 天长市| 巴里| 来凤县| 洪洞县| 边坝县| 喀喇沁旗| 措勤县| 通州区| 穆棱市| 上犹县| 柳州市| 株洲县| 合川市|