




已閱讀5頁,還剩16頁未讀, 繼續(xù)免費(fèi)閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
Hibernate第五天,注解的實(shí)體關(guān)聯(lián)映射 Hibernate的緩存機(jī)制,單向的one-to-many,OneToMany注解:是指示在多的一方使用1的一方的主鍵作為其外鍵,關(guān)聯(lián)1的一方 JoinColumn指明在多的一方關(guān)聯(lián)1的一方的外鍵名稱,單向的many-to-one,ManyToOne JoinColumn 在多的一方引用1的一方的變量getter方法上加上以上兩個(gè)注解 ManyToOne表示在本類對應(yīng)的數(shù)據(jù)庫表中生成關(guān)聯(lián)1的一方主鍵的外鍵 其中JoinColumn中的name表示當(dāng)前實(shí)體bean對應(yīng)的數(shù)據(jù)庫表與1的一方的數(shù)據(jù)庫表關(guān)聯(lián)的外鍵名稱,雙向的one-to-many,在1的一方,使用OneToMany注解 其中mappedBy的值對應(yīng)另一方對本實(shí)體bean的引用變量 在多的一方,使用ManyToOne注解和JoinColumn注解,其中JoinColumn指示在多的一方對應(yīng)的數(shù)據(jù)庫表中生成外鍵關(guān)聯(lián)1的一方。,雙向many-to-many,ManyToMany注解 JoinTable 在雙向Many-to-Many關(guān)系映射中,包含兩方面,擁有方和被擁有方(inverse一方)。在擁有方指明通過哪張表來和被擁有方維護(hù)映射關(guān)系。 被擁有方使用ManyToMany CascadeType.REFRESH:級聯(lián)刷新,當(dāng)多個(gè)用戶同時(shí)作操作一個(gè)實(shí)體,為了用戶取到的數(shù)據(jù)是實(shí)時(shí)的,在用實(shí)體中的數(shù)據(jù)之前就可以調(diào)用一下refresh()方法! CascadeType.REMOVE:級聯(lián)刪除,當(dāng)調(diào)用remove()方法刪除A實(shí)體時(shí)會先級聯(lián)刪除B的相關(guān)數(shù)據(jù)! CascadeType.MERGE:級聯(lián)更新,當(dāng)調(diào)用了Merge()方法,如果A中的數(shù)據(jù)改變了會相應(yīng)的更新B中的數(shù)據(jù), CascadeType.PERSIST:級聯(lián)保存,當(dāng)調(diào)用了Persist() 方法,會級聯(lián)保存相應(yīng)的數(shù)據(jù) CascadeType.ALL:包含以上所有級聯(lián)屬性。,什么是緩存,緩存是介于物理數(shù)據(jù)源與應(yīng)用程序之間,是對數(shù)據(jù)庫中的數(shù)據(jù)復(fù)制一份臨時(shí)放在內(nèi)存中的容器,其作用是為了減少應(yīng)用程序?qū)ξ锢頂?shù)據(jù)源訪問的次數(shù),從而提高了應(yīng)用程序的運(yùn)行性能。Hibernate在進(jìn)行讀取數(shù)據(jù)的時(shí)候,根據(jù)緩存機(jī)制在相應(yīng)的緩存中查詢,如果在緩存中找到了需要的數(shù)據(jù)(我們把這稱做“緩存命 中“),則就直接把命中的數(shù)據(jù)作為結(jié)果加以利用,避免了大量發(fā)送SQL語句到數(shù)據(jù)庫查詢的性能損耗。,緩存策略供應(yīng)商,提供了HashTable緩存,EHCache,OSCache,SwarmCache,jBoss Cathe2,這些緩存機(jī)制,其中EHCache,OSCache是不能用于集群環(huán)境(Cluster Safe)的,而SwarmCache,jBoss Cathe2是可以的。HashTable緩存主要是用來測試的,只能把對象放在內(nèi)存中,EHCache,OSCache可以把對象放在內(nèi)存(memory)中,也可以把對象放在硬盤(disk)上。,緩存分類,一、Session緩存(又稱作事務(wù)緩存,一級緩存):Hibernate內(nèi)置的,不能卸除。 緩存范圍:緩存只能被當(dāng)前Session對象訪問。緩存的生命周期依賴于Session的生命周期,當(dāng)Session被關(guān)閉后,緩存也就結(jié)束生命周期。 二、SessionFactory緩存(又稱作應(yīng)用緩存,二級緩存):使用第三方插件,可插拔。 緩存范圍:緩存被應(yīng)用范圍內(nèi)的所有session共享,不同的Session可以共享。這些session有可能是并發(fā)訪問緩存,因此必須對緩存進(jìn)行更新。緩存的生命周期依賴于應(yīng)用的生命周期,應(yīng)用結(jié)束時(shí),緩存也就結(jié)束了生命周期,二級緩存存在于應(yīng)用程序范圍。,一級緩存的管理和使用,數(shù)據(jù)放入緩存: 1. save()。當(dāng)session對象調(diào)用save()方法保存一個(gè)對象后,該對象會被放入到session的緩存中。 2. get()和load()。當(dāng)session對象調(diào)用get()或load()方法從數(shù)據(jù)庫取出一個(gè)對象后,該對象也會被放入到session的緩存中。 3. 使用HQL和QBC等從數(shù)據(jù)庫中查詢數(shù)據(jù)。,一級緩存的清除,1. evict()將指定的持久化對象從緩存中清除,釋放對象所占用的內(nèi)存資源,指定對象從持久化狀態(tài)變?yōu)槊摴軤顟B(tài),從而成為游離對象。 2. clear()將緩存中的所有持久化對象清除,釋放其占用的內(nèi)存資源。,其他操作,1. contains()判斷指定的對象是否存在于緩存中。 2. flush()刷新緩存區(qū)的內(nèi)容,使之與數(shù)據(jù)庫數(shù)據(jù)保持同步。,二級緩存的配置、管理和使用,當(dāng)我們重啟一個(gè)Session,第二次調(diào)用load或者get方法檢索同一個(gè)對象的時(shí)候會重新查找數(shù)據(jù)庫,會發(fā)select語句信息。 原因:一個(gè)session不能取另一個(gè)session中的緩存。 性能上的問題:假如是多線程同時(shí)去取Category這個(gè)對象,load一個(gè)對象,這個(gè)對像本來可以放到內(nèi)存中的,可是由于是多線程,是分布在不同的session當(dāng)中的,所以每次都要從數(shù)據(jù)庫中取,這樣會帶來查詢性能較低的問題。 解決方案:使用二級緩存。,二級緩存,1.什么是二級緩存? SessionFactory級別的緩存,可以跨越Session存在,可以被多個(gè)Session所共享。 2.適合放到二級緩存中: (1)經(jīng)常被訪問 (2)改動(dòng)不大 (3)數(shù)量有限 (4)不是很重要的數(shù)據(jù),允許出現(xiàn)偶爾并發(fā)的數(shù)據(jù)。 這樣的數(shù)據(jù)非常適合放到二級緩存中的。 用戶的權(quán)限:用戶的數(shù)量不大,權(quán)限不多,不會經(jīng)常被改動(dòng),經(jīng)常被訪問。,實(shí)現(xiàn)原理,Hibernate如何將數(shù)據(jù)庫中的數(shù)據(jù)放入到二級緩存中?注意,你可以把緩存看做是一個(gè)Map對象,它的Key用于存儲對象OID,Value用于存儲POJO。首先,當(dāng)我們使用Hibernate從數(shù)據(jù)庫中查詢出數(shù)據(jù),獲取檢索的數(shù)據(jù)后,Hibernate將檢索出來的對象的OID放入緩存中key 中,然后將具體的POJO放入value中,等待下一次再次向數(shù)據(jù)查詢數(shù)據(jù)時(shí),Hibernate根據(jù)你提供的OID先檢索一級緩存,若有且配置了二級緩存,則檢索二級緩存,如果還沒有則才向數(shù)據(jù)庫發(fā)送SQL語句,然后將查詢出來的對象放入緩存中。,開啟二級緩存,1、修改hibernate.cfg.xml: true org.hibernate.cache.ehcache.EhCacheRegionFactory ,在實(shí)體類中加入注解,需要導(dǎo)包: liboptionalehcache ehcache-core-2.4.3.jar liboptionalehcache hibernate-ehcache-4.3.7.Final.jar liboptionalehcache slf4j-api-1.6.1.jar 在實(shí)體類中通過注解可以配置使用二級緩存: Cache(usage = CacheConcurrencyStrategy.READ_WRITE) Load默認(rèn)使用二級緩存,就是當(dāng)查一個(gè)對象的時(shí)候,它先會去二級緩存里面去找,如果找到了就不去數(shù)據(jù)庫中查了。 Iterator默認(rèn)的也會使用二級緩存,有的話就不去數(shù)據(jù)庫里面查了,不發(fā)送select語句了。 List默認(rèn)的往二級緩存中加數(shù)據(jù),假如有一個(gè)query,把數(shù)據(jù)拿出來之后會放到二級緩存,但是執(zhí)行查詢的時(shí)候不會到二級緩存中查,會在數(shù)據(jù)庫中查。原因每個(gè)query中查詢條件不一樣。,也可以在需要被緩存的對象中hbm文件中的標(biāo)簽下添加一個(gè)子標(biāo)簽: seq_part_hql ,存在一對多的關(guān)系,想要在在獲取一方的時(shí)候?qū)㈥P(guān)聯(lián)的多方緩存起來,需要在下面幾個(gè)位置添加添加子標(biāo)簽,不然Hibernate只會緩存OID。 位置0、一的一方在hbm中的下面添加 位置1、一的一方在hbm中的集合下面添加 位置2、多的一方在hbm中的下面添加,查詢緩存的配置、管理和使用,1、查詢緩存及應(yīng)用的場合 它是針對HQL語句的緩存(只在以HQL方式進(jìn)行查詢時(shí)產(chǎn)生) 不適用于數(shù)據(jù)變更頻繁、查詢條件相同的場合 2、啟用查詢緩存 Hibernate的查詢緩存默認(rèn)是關(guān)閉的,可以通過下面的操作打開: 在hibernate.cfg.xml中: true,1、在執(zhí)行query.list()方法查詢時(shí)首先檢查是否配置了查詢緩存,如果配置了則從查詢緩存中查找key為“查詢語句+查詢參數(shù)+分頁條件“的值,如果獲取不到則從數(shù)據(jù)庫進(jìn)行獲取。 2、hibernate根據(jù)這些信息組成一個(gè)query key,query key包括條件查詢請求的一般信息:SQL、SQL需要的參數(shù)、記錄范圍(起始位置rowStart,最大
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 公司每月生日會策劃方案
- 2025年職業(yè)教育與成人繼續(xù)教育專業(yè)能力考核試題及答案
- 2025年醫(yī)學(xué)影像技術(shù)考試試卷及答案
- 2025年社會保障與就業(yè)考試題及答案
- 畜禽糞污資源化技術(shù)-洞察及研究
- 2025年教育信息化與學(xué)習(xí)平臺構(gòu)建考試試卷及答案
- 2025年環(huán)境工程師資格考試試卷及答案
- 2025年廣告與傳播專業(yè)考試試題及答案
- 2024年度浙江省二級造價(jià)工程師之建設(shè)工程造價(jià)管理基礎(chǔ)知識提升訓(xùn)練試卷B卷附答案
- 2024年度浙江省二級注冊建筑師之法律法規(guī)經(jīng)濟(jì)與施工題庫附答案(基礎(chǔ)題)
- (完整版)傳熱學(xué)期末考試試題
- JCT587-2012 玻璃纖維纏繞增強(qiáng)熱固性樹脂耐腐蝕立式貯罐
- Python數(shù)據(jù)分析與數(shù)據(jù)挖掘 課件 第6、7章 Pandas基礎(chǔ)與應(yīng)用、Matplotlib
- 玻璃體手術(shù)并發(fā)癥的預(yù)防及處理
- 2023年醫(yī)學(xué)高級職稱-中醫(yī)肛腸(醫(yī)學(xué)高級)考試歷年高頻考點(diǎn)試題含答案
- 爬架拆除技術(shù)交底
- pergeos軟件教程評價(jià)許可介紹
- 密封條范文模板(A4打印版)
- 出租車 專業(yè)部分考核試題 城市客運(yùn)企業(yè)主要負(fù)責(zé)人和安全生產(chǎn)管理人員安全考核基礎(chǔ)題庫
- GB/T 9634.3-2002鐵氧體磁心表面缺陷極限導(dǎo)則第3部分:ETD和E形磁心
- GB/T 8478-2008鋁合金門窗
評論
0/150
提交評論