已閱讀5頁,還剩16頁未讀, 繼續(xù)免費閱讀
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
Hibernate第五天,注解的實體關(guān)聯(lián)映射 Hibernate的緩存機制,單向的one-to-many,OneToMany注解:是指示在多的一方使用1的一方的主鍵作為其外鍵,關(guān)聯(lián)1的一方 JoinColumn指明在多的一方關(guān)聯(lián)1的一方的外鍵名稱,單向的many-to-one,ManyToOne JoinColumn 在多的一方引用1的一方的變量getter方法上加上以上兩個注解 ManyToOne表示在本類對應(yīng)的數(shù)據(jù)庫表中生成關(guān)聯(lián)1的一方主鍵的外鍵 其中JoinColumn中的name表示當(dāng)前實體bean對應(yīng)的數(shù)據(jù)庫表與1的一方的數(shù)據(jù)庫表關(guān)聯(lián)的外鍵名稱,雙向的one-to-many,在1的一方,使用OneToMany注解 其中mappedBy的值對應(yīng)另一方對本實體bean的引用變量 在多的一方,使用ManyToOne注解和JoinColumn注解,其中JoinColumn指示在多的一方對應(yīng)的數(shù)據(jù)庫表中生成外鍵關(guān)聯(lián)1的一方。,雙向many-to-many,ManyToMany注解 JoinTable 在雙向Many-to-Many關(guān)系映射中,包含兩方面,擁有方和被擁有方(inverse一方)。在擁有方指明通過哪張表來和被擁有方維護映射關(guān)系。 被擁有方使用ManyToMany CascadeType.REFRESH:級聯(lián)刷新,當(dāng)多個用戶同時作操作一個實體,為了用戶取到的數(shù)據(jù)是實時的,在用實體中的數(shù)據(jù)之前就可以調(diào)用一下refresh()方法! CascadeType.REMOVE:級聯(lián)刪除,當(dāng)調(diào)用remove()方法刪除A實體時會先級聯(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ù)制一份臨時放在內(nèi)存中的容器,其作用是為了減少應(yīng)用程序?qū)ξ锢頂?shù)據(jù)源訪問的次數(shù),從而提高了應(yīng)用程序的運行性能。Hibernate在進行讀取數(shù)據(jù)的時候,根據(jù)緩存機制在相應(yīng)的緩存中查詢,如果在緩存中找到了需要的數(shù)據(jù)(我們把這稱做“緩存命 中“),則就直接把命中的數(shù)據(jù)作為結(jié)果加以利用,避免了大量發(fā)送SQL語句到數(shù)據(jù)庫查詢的性能損耗。,緩存策略供應(yīng)商,提供了HashTable緩存,EHCache,OSCache,SwarmCache,jBoss Cathe2,這些緩存機制,其中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ā)訪問緩存,因此必須對緩存進行更新。緩存的生命周期依賴于應(yīng)用的生命周期,應(yīng)用結(jié)束時,緩存也就結(jié)束了生命周期,二級緩存存在于應(yīng)用程序范圍。,一級緩存的管理和使用,數(shù)據(jù)放入緩存: 1. save()。當(dāng)session對象調(diào)用save()方法保存一個對象后,該對象會被放入到session的緩存中。 2. get()和load()。當(dāng)session對象調(diào)用get()或load()方法從數(shù)據(jù)庫取出一個對象后,該對象也會被放入到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)我們重啟一個Session,第二次調(diào)用load或者get方法檢索同一個對象的時候會重新查找數(shù)據(jù)庫,會發(fā)select語句信息。 原因:一個session不能取另一個session中的緩存。 性能上的問題:假如是多線程同時去取Category這個對象,load一個對象,這個對像本來可以放到內(nèi)存中的,可是由于是多線程,是分布在不同的session當(dāng)中的,所以每次都要從數(shù)據(jù)庫中取,這樣會帶來查詢性能較低的問題。 解決方案:使用二級緩存。,二級緩存,1.什么是二級緩存? SessionFactory級別的緩存,可以跨越Session存在,可以被多個Session所共享。 2.適合放到二級緩存中: (1)經(jīng)常被訪問 (2)改動不大 (3)數(shù)量有限 (4)不是很重要的數(shù)據(jù),允許出現(xiàn)偶爾并發(fā)的數(shù)據(jù)。 這樣的數(shù)據(jù)非常適合放到二級緩存中的。 用戶的權(quán)限:用戶的數(shù)量不大,權(quán)限不多,不會經(jīng)常被改動,經(jīng)常被訪問。,實現(xiàn)原理,Hibernate如何將數(shù)據(jù)庫中的數(shù)據(jù)放入到二級緩存中?注意,你可以把緩存看做是一個Map對象,它的Key用于存儲對象OID,Value用于存儲POJO。首先,當(dāng)我們使用Hibernate從數(shù)據(jù)庫中查詢出數(shù)據(jù),獲取檢索的數(shù)據(jù)后,Hibernate將檢索出來的對象的OID放入緩存中key 中,然后將具體的POJO放入value中,等待下一次再次向數(shù)據(jù)查詢數(shù)據(jù)時,Hibernate根據(jù)你提供的OID先檢索一級緩存,若有且配置了二級緩存,則檢索二級緩存,如果還沒有則才向數(shù)據(jù)庫發(fā)送SQL語句,然后將查詢出來的對象放入緩存中。,開啟二級緩存,1、修改hibernate.cfg.xml: true org.hibernate.cache.ehcache.EhCacheRegionFactory ,在實體類中加入注解,需要導(dǎo)包: liboptionalehcache ehcache-core-2.4.3.jar liboptionalehcache hibernate-ehcache-4.3.7.Final.jar liboptionalehcache slf4j-api-1.6.1.jar 在實體類中通過注解可以配置使用二級緩存: Cache(usage = CacheConcurrencyStrategy.READ_WRITE) Load默認(rèn)使用二級緩存,就是當(dāng)查一個對象的時候,它先會去二級緩存里面去找,如果找到了就不去數(shù)據(jù)庫中查了。 Iterator默認(rèn)的也會使用二級緩存,有的話就不去數(shù)據(jù)庫里面查了,不發(fā)送select語句了。 List默認(rèn)的往二級緩存中加數(shù)據(jù),假如有一個query,把數(shù)據(jù)拿出來之后會放到二級緩存,但是執(zhí)行查詢的時候不會到二級緩存中查,會在數(shù)據(jù)庫中查。原因每個query中查詢條件不一樣。,也可以在需要被緩存的對象中hbm文件中的標(biāo)簽下添加一個子標(biāo)簽: seq_part_hql ,存在一對多的關(guān)系,想要在在獲取一方的時候?qū)㈥P(guān)聯(lián)的多方緩存起來,需要在下面幾個位置添加添加子標(biāo)簽,不然Hibernate只會緩存OID。 位置0、一的一方在hbm中的下面添加 位置1、一的一方在hbm中的集合下面添加 位置2、多的一方在hbm中的下面添加,查詢緩存的配置、管理和使用,1、查詢緩存及應(yīng)用的場合 它是針對HQL語句的緩存(只在以HQL方式進行查詢時產(chǎn)生) 不適用于數(shù)據(jù)變更頻繁、查詢條件相同的場合 2、啟用查詢緩存 Hibernate的查詢緩存默認(rèn)是關(guān)閉的,可以通過下面的操作打開: 在hibernate.cfg.xml中: true,1、在執(zhí)行query.list()方法查詢時首先檢查是否配置了查詢緩存,如果配置了則從查詢緩存中查找key為“查詢語句+查詢參數(shù)+分頁條件“的值,如果獲取不到則從數(shù)據(jù)庫進行獲取。 2、hibernate根據(jù)這些信息組成一個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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版建筑工程施工監(jiān)理單位招標(biāo)投標(biāo)合同書3篇
- 二零二五版古籍文獻儲藏室修復(fù)合同3篇
- 二零二五年度高品質(zhì)膩子施工服務(wù)供應(yīng)合同2篇
- 二零二五版導(dǎo)游人員旅游安全責(zé)任合同3篇
- 小區(qū)車子棚施工合同(2篇)
- 2025年度新能源項目財務(wù)監(jiān)督出納人員擔(dān)保合同2篇
- 二零二五版車位購置及租賃合同樣本12篇
- 2025年度欠條收藏:古董字畫修復(fù)與交易合同3篇
- 二零二五年度高新技術(shù)項目研發(fā)團隊聘用合同范本3篇
- 二零二五年餐飲服務(wù)人員勞動合同樣本12篇
- HG∕T 2058.1-2016 搪玻璃溫度計套
- 九宮數(shù)獨200題(附答案全)
- 泌尿科一科一品匯報課件
- 人員密集場所消防安全管理培訓(xùn)
- 白銅錫電鍍工藝
- 拜耳法氧化鋁生產(chǎn)工藝
- 2024年南京信息職業(yè)技術(shù)學(xué)院高職單招(英語/數(shù)學(xué)/語文)筆試歷年參考題庫含答案解析
- 部編版二年級下冊道德與法治第二單元《我們好好玩》全部教案
- 幼兒園利劍護蕾專項行動工作方案總結(jié)與展望
- 合同信息管理方案模板范文
- 2024年大唐云南發(fā)電有限公司招聘筆試參考題庫含答案解析
評論
0/150
提交評論