hibernate 簡介:
hibernate是一個開源框架,它是對象關聯關係映射的框架,它對JDBC作了輕量級的封裝,而咱們java程序員可使用面向對象的思想來操縱數據庫。
hibernate核心接口
session:負責被持久化對象CRUD操做
sessionFactory:負責初始化hibernate,建立session對象
configuration:負責配置並啓動hibernate,建立SessionFactory
Transaction:負責事物相關的操做
Query和Criteria接口:負責執行各類數據庫查詢
hibernate工做原理:
1.經過Configuration config = new Configuration().configure();//讀取並解析hibernate.cfg.xml配置文件
2.由hibernate.cfg.xml中的<mapping resource="com/xx/User.hbm.xml"/>讀取並解析映射信息
3.經過SessionFactory sf = config.buildSessionFactory();//建立SessionFactory
4.Session session = sf.openSession();//打開Sesssion
5.Transaction tx = session.beginTransaction();//建立並啓動事務Transation
6.persistent operate操做數據,持久化操做
7.tx.commit();//提交事務
8.關閉Session
9.關閉SesstionFactory
爲何要用hibernate:
1. 對JDBC訪問數據庫的代碼作了封裝,大大簡化了數據訪問層繁瑣的重複性代碼。
2. Hibernate是一個基於JDBC的主流持久化框架,是一個優秀的ORM實現。他很大程度的簡化DAO層的編碼工做
3. hibernate使用Java反射機制,而不是字節碼加強程序來實現透明性。
4. hibernate的性能很是好,由於它是個輕量級框架。映射的靈活性很出色。它支持各類關係數據庫,從一對一到多對多的各類複雜關係。
Hibernate是如何延遲加載?get與load的區別html
1. 對於Hibernate get方法,Hibernate會確認一下該id對應的數據是否存在,首先在session緩存中查找,而後在二級緩存中查找,尚未就查詢數據庫,數據 庫中沒有就返回null。這個相對比較簡單,也沒有太大的爭議。主要要說明的一點就是在這個版本(bibernate3.2以上)中get方法也會查找二級緩存!java
2. Hibernate load方法加載實體對象的時候,根據映射文件上類級別的lazy屬性的配置(默認爲true),分狀況討論: 程序員
(1)若爲true,則首先在Session緩存中查找,看看該id對應的對象是否存在,不存在則使用延遲加載,返回實體的代理類對象(該代理類爲實體類的子類,由CGLIB動態生成)。等到具體使用該對象(除獲取OID之外)的時候,再查詢二級緩存和數據庫,若仍沒發現符合條件的記錄,則會拋出一個ObjectNotFoundException。數據庫
(2)若爲false,就跟Hibernateget方法查找順序同樣,只是最終若沒發現符合條件的記錄,則會拋出一個ObjectNotFoundException。緩存
這裏get和load有兩個重要區別: session
若是未能發現符合條件的記錄,Hibernate get方法返回null,而load方法會拋出一個ObjectNotFoundException。併發
load方法可返回沒有加載實體數據的代 理類實例,而get方法永遠返回有實體數據的對象。app
(對於load和get方法返回類型:好多書中都說:「get方法永遠只返回實體類」,實際上並不正 確,get方法若是在session緩存中找到了該id對應的對象,若是恰好該對象前面是被代理過的,如被load方法使用過,或者被其餘關聯對象延遲加 載過,那麼返回的仍是原先的代理對象,而不是實體類對象,若是該代理對象尚未加載實體數據(就是id之外的其餘屬性數據),那麼它會查詢二級緩存或者數 據庫來加載數據,可是返回的仍是代理對象,只不過已經加載了實體數據。)框架
總之對於get和load的根本區別,一句話,hibernate對於 load方法認爲該數據在數據庫中必定存在,能夠放心的使用代理來延遲加載,若是在使用過程當中發現了問題,只能拋異常;而對於get方 法,hibernate必定要獲取到真實的數據,不然返回null。函數
Hibernate中怎樣實現類之間的關係?(如:一對多、多對多的關係)
類與類之間的關係主要體如今表與表之間的關係進行操做,它們都市對對象進行操做,咱們程序中把全部的表與類都映射在一塊兒,它們經過配置文件中的many-to-one、one-to-many、many-to-many、
說下Hibernate的緩存機制:
Hibernate的查詢方式
Sql、Criteria,object comptosition
Hql:
一、 屬性查詢
二、 參數查詢、命名參數查詢
三、 關聯查詢
四、 分頁查詢
五、 統計函數
如何優化Hibernate?
1.使用雙向一對多關聯,不使用單向一對多
2.靈活使用單向一對多關聯
3.不用一對一,用多對一取代
4.配置對象緩存,不使用集合緩存
5.一對多集合使用Bag,多對多集合使用Set
6. 繼承類使用顯式多態
7. 表字段要少,表關聯不要怕多,有二級緩存撐腰
hibernate的開發步驟:
開發步驟
1)搭建好環境
引入hibernate最小的jar包
準備Hibernate.cfg.xml啓動配置文件
2)寫實體類(pojo)
3)爲實體類寫映射文件"User.hbm.xml"
在hibernate.cfg.xml添加映射的實體
4)建立庫表
5)寫測試類
得到Configuration
建立SessionFactory
打開Session
開啓事務
使用session操做數據
提交事務
關閉資源