資源描述:
《hibernate事務(wù)與jdbc事務(wù)結(jié)合問(wèn)題.pdf》由會(huì)員上傳分享,免費(fèi)在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫(kù)。
1、Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日測(cè)試一:Dao代碼:Service代碼:頁(yè)面1Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日在Hibernate事務(wù)與JDBC事務(wù)都配置的情況下執(zhí)行service方法,成功插入了兩條數(shù)據(jù)時(shí)間不一樣這是因?yàn)楸镜貢r(shí)間和數(shù)據(jù)庫(kù)時(shí)間不一致,不影響測(cè)試頁(yè)面2Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日測(cè)試二:spring配置不變,兩種事務(wù)都配置Dao:addGuest1方法不變,讓addGuest2方法報(bào)錯(cuò),不設(shè)置Ismem的值,但是數(shù)據(jù)庫(kù)是不允許為空的。頁(yè)面3Hibernate事務(wù)與J
2、DBC事務(wù)結(jié)合問(wèn)題2010年11月16日Service代碼不變執(zhí)行:控制臺(tái)報(bào)錯(cuò)查看數(shù)據(jù)庫(kù):之前已經(jīng)把上次的數(shù)據(jù)刪除,再查看發(fā)現(xiàn)是空的,這說(shuō)明hibernate事務(wù)起作用了,方法2報(bào)錯(cuò)造成了方法1的回滾現(xiàn)在換讓方法1報(bào)錯(cuò),方法2正常,然后在service里把這兩個(gè)方法的執(zhí)行順序調(diào)換頁(yè)面4Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日dao方法Service方法頁(yè)面5Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日?qǐng)?zhí)行:控制臺(tái)報(bào)錯(cuò)not-nullpropertyreferencesanullortransientvalue:com.fzdna.app
3、lication.agent.dto.domain.extend.shop.ShpGuestDto.ismem查看數(shù)據(jù)庫(kù)是空的,說(shuō)明方法1的報(bào)錯(cuò)造成了方法2的回滾,證明JDBC事務(wù)起作用了測(cè)試三:修改spring配置,只配置Hibernate事務(wù),JDBC事務(wù)去掉dao方法讓方法1報(bào)錯(cuò),service方法先執(zhí)行方法2,再執(zhí)行方法1頁(yè)面6Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日?qǐng)?zhí)行后查詢數(shù)據(jù)庫(kù):發(fā)現(xiàn)JDBC的數(shù)據(jù)插進(jìn)去了,并沒(méi)有回滾。再增加個(gè)正確的hibernate增加方法試下頁(yè)面7Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日?qǐng)?zhí)行后查詢數(shù)
4、據(jù)庫(kù):發(fā)現(xiàn)還是JDBC的數(shù)據(jù)插入進(jìn)去了,并沒(méi)有回滾。這說(shuō)明,hibernate事務(wù)無(wú)法控制JDBC的操作,對(duì)自己hibernate的操作可以正?;貪L。測(cè)試四:spring配置改為JDBC事務(wù)打開(kāi),Hibernate事務(wù)關(guān)閉讓addGuest1方法正確,addGuest2方法報(bào)錯(cuò),執(zhí)行順序如下頁(yè)面8Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日查看數(shù)據(jù)庫(kù)如下,發(fā)現(xiàn)hibernate方法插進(jìn)去了,也并沒(méi)有回滾再增加個(gè)正確的JDBC方法測(cè)試下Service方法改為:執(zhí)行后查看數(shù)據(jù)庫(kù)頁(yè)面9Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日?qǐng)?zhí)行后查詢數(shù)據(jù)庫(kù):
5、發(fā)現(xiàn)還是hibernate的數(shù)據(jù)插入進(jìn)去了,并沒(méi)有回滾。這說(shuō)明,JDBC事務(wù)無(wú)法控制hibernate的操作,對(duì)自己JDBC的操作可以正?;貪L。測(cè)試五:在上個(gè)配置不變的情況下繼續(xù)修改spring配置頁(yè)面10Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日Dao:還是讓jdbc方法報(bào)錯(cuò)Service:頁(yè)面11Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日?qǐng)?zhí)行結(jié)果:hibernate事務(wù)回滾了,但是我們并沒(méi)有配置hibernate事務(wù)在service里多加幾個(gè)方法測(cè)試下頁(yè)面12Hibernate事務(wù)與JDBC事務(wù)結(jié)合問(wèn)題2010年11月16日無(wú)論hi
6、bernate方法報(bào)錯(cuò),還是JDBC方法報(bào)錯(cuò),都全部回滾了說(shuō)明這段配置起作用了,下面我們來(lái)看下useTransactionAwareDataSource這是個(gè)什么東西?字面意思是讓事務(wù)知道數(shù)據(jù)源。頁(yè)面13packageorg.springframework.orm.hibernate3;publicclassLocalSessionFactoryBeanextendsAbstractSessionFactoryBeanimplementsBeanClassLoaderAware{privatestaticfinalThreadLocalconfigTimeDa
7、taSourceHolder=newThreadLocal();if(dataSource!=null){//MakegivenDataSourceavailableforSessionFactoryconfiguration.configTimeDataSourceHolder.set(dataSource);}......................………………….結(jié)束返回是否使用SessionFactory的事務(wù)感知數(shù)據(jù)源