1. 程式人生 > >Hibernate基礎知識詳解

Hibernate基礎知識詳解

seq 每次 事務 name rep cfg 默認 poj 產生

一、Hibernate框架
Hibernate是一個開放源代碼的對象關系映射框架,它對 JDBC進行了非常輕量級的對象封裝,它將POJO類與數據庫表建立映射關系,是一個
全自動的ORM框架,hibernate可以自動生成SQL語句,自動執行。Hibernate可以應用在任何使用 DBC的場合,既可以在Java的客戶端程序使用,
也可以在Servlet/JSP的Web應用中使用。Hibernate下載orm,jar包官網:https://hibernate.org/orm/releases/
二、ORM(對象關系映射)模型框架
用於實現面向對象編程語言裏不同類型系統的數據之間的轉換。對象關系映射,是隨著面向對象的軟件開發方法發展而產生的。面向對象的
開發方法是當今主流開發方法,關系數據庫是應用環境中永久存放數據的主流數據存儲系統。對象和關系數據是業務實體的兩種表現形式,業務
實體在內存中表現為對象,在數據庫中表現為關系數據。內存中的對象之間存在關聯和繼承關系,而在數據庫中,關系數據無法直接表達多對多
關聯和繼承關系。因此,ORM系統一般以中間件的形式存在,主要實現程序對象到關系數據庫數據的映射。
三、Hibernate配置文件


1.映射文件
映射配置文件主要是用於描述實體類與數據表之間的映射關系。位置要與實體類在同一個包下。名稱:類名.hbm.xml

      <hibernate-mapping>
            <class name="*.*.*" table="t_customer" catalog="***">
                <id name="id" column="c_id">
                    <generator class="identity" />
                </
id> <property name="name" column="c_name" length="20" /> <set name="orders" inverse="false" cascade="save-update"> <key column="c_customer_id" /> </set> </class>
</hibernate-mapping>

(1)統一聲明包名,這樣在<class>中就不需要寫類的全名。
(2)關於<class>標簽配置
name 屬性:類的全名稱
table 表的名稱,可以省略,這時表的名稱就與類名一致
catalog 屬性:數據庫名稱 可以省略.如果省略,參考核心配置文件中 url 路徑中的庫名稱
(3)關於<id>標簽,<id>是用於建立類中的屬性與表中的主鍵映射。
name 類中的屬性名稱
column 表中的主鍵名稱 column 它也可以省略,這時列名就與類中屬性名稱一致
length 字段長度
type 屬性 指定類型
<generator>它主要是描述主鍵生成策略。
(4)關於<property>標簽 ,是描述類中屬性與表中非主鍵的映射關系。
2.核心配置文件
主要包含了連接數據庫相關信息,hibernate相關配置等。位置:在項目根目錄下創建一個。名稱:hibernate.cfg.xml
根據hibernate.properties文件下的信息可以配置

<hibernate-configuration>
            <session-factory>
                <!-- 配置關於數據庫連接的四個項 driverClass url username password -->
                <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
                <property name="hibernate.connection.url">jdbc:mysql:///**</property>
                <property name="hibernate.connection.username">***</property>
                <property name="hibernate.connection.password">***</property>

                <!-- 設置連接提供者 -->
                <property name="hibernate.connection.provider_class">org.hibernate.c3p0.internal.C3P0ConnectionProvider</property>
                <!-- c3p0連接池的配置 -->
                <property name="hibernate.c3p0.max_size">20</property> <!-- 最大連接池 -->
                <property name="hibernate.c3p0.min_size">5</property> <!-- 最小連接數 -->
                <property name="hibernate.c3p0.timeout">120</property> <!-- 超時 -->
                <property name="hibernate.c3p0.idle_test_period">3000</property> <!-- 空閑連接 -->

                <!-- 可以將向數據庫發送的sql顯示出來 -->
                <property name="hibernate.show_sql">true</property>
                <!-- 格式化sql -->
                <property name="hibernate.format_sql">true</property>

                <!-- hibernate的方言 -->
                <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>

                <!-- 自動創建表 -->
                <property name="hibernate.hbm2ddl.auto">create</property>

                <!-- 用於設置事務提交方式 -->
                <property name="hibernate.connection.autocommit">false</property>

                <!-- 配置hibernate的映射文件所在位置 -->
                <mapping resource=".././*.hbm.xml" />
                
            </session-factory>
        </hibernate-configuration>    

註意:無論是映射文件還是核心配置文件,都要有約束在xml文件中,已3.0.dtd為例:

 <!DOCTYPE hibernate-configuration PUBLIC
           "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
                "http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

位置是:hibernate的jar包下的\project\etc\hibernate.properties
四、Hibernate工作原理:
1.通過 Configuration().configure(); 讀取並解析 hibernate.cfg.xml 配置文件。
2.由hibernate.cfg.xml中的<mappingresource="xx/xx/xxx.hbm.xml"/> 讀取解析映射信息。
3.通過 config.buildSessionFactory(); 得到 sessionFactory。
4.sessionFactory.openSession(); 得到 session。
5.session.beginTransaction(); 開啟事務。
6.session.getTransaction().commit(); 提交事務
7.關閉 session;
五、Hibernate持久化類與 主鍵生成策略
在 hbm.xml 中可以設置的主鍵生成策略如下:
主鍵生成器 描述
increment 代理主鍵。由 hibernate 維護一個變量,每次生成主鍵時自動以遞增。 問題:如果有多個應用訪問一個數據庫,由於每個應用維護自己                         的主鍵。此時主鍵可能沖突。建議不采用。
identity 代理主鍵。由底層數據庫生成表識符。條件是數據庫支持自動增長數據類型。 比如:mysql 的自增主鍵,oracle 不支持主鍵自動生成。                         如果數據庫支持自增建議采用。
sequence 代理主鍵。Hibernate 根據底層數據庫序列生成標識符。條件是數據庫支持序 列。比如 oracle 的序列。如果數據庫支持序列建議采用。
native 代理主鍵。根據底層數據庫對自動來選擇 identity、sequence、hilo由於生成主鍵策略的控制權由 hibernate 控制,所以不建議采用。
uuid   代理主鍵。Hibernate 采用 128 位的 UUID 算法來生成標識符。該算法能夠在網絡環境中生成唯一的字符串標識符。此策略可以保證生                         成主鍵的唯一性,並且提供了最好的數據庫插入性能和數據庫平臺的無關性。建議采用。
assigned 自然主鍵。由 java 程序負責生成標識符。不建議采用。
六、Hibernate持久化對象狀態
1. 瞬時態:也叫做臨時態或自由態,它一般指我們new出來的對象,它不存在OID,與hibernate session無關聯,在數據庫中也無記錄。它使用
完成後,會被jvm直接回收掉,它只是用於信息攜帶。
簡單說:無OID與數據庫中的信息無關聯,不在 session 管理範圍內。
2. 持久態:在 hibernate session 管理範圍內,它具有持久化標識OID它的特點,在事務未提交前一直是持久態,當它發生改變時,hibernate
是可以檢測到的。
簡單說:有OID 由session管理,在數據庫中有可能有,也有可有沒有。
3. 托管態:也叫做遊離態或離線態,它是指持久態對象失去了與session的關聯,托管態對象它存在OID,在數據庫中有可能存在,也有可能不
存在。對於托管態對象,它發生改變時hibernet不能檢測到。
七、Hibernate註解開發
1.PO類註解開發
@Entity 聲明一個實體
@Table 來描述類與表對應
@Id 來聲明一個主鍵
@GenerateValue 用它來聲明一個主鍵生成策略
默認情況下相當於native,可以選擇的主鍵生成策略 AUTO IDENTITY SEQUENCE
@Column 來定義列
註意:對於 PO 類中所有屬性,如果你不寫註解,默認情況下也會在表中生成對應的列。列的名稱就是屬性的名稱
@Temporal 來聲明日期類型
TemporalType.DATA 只有年月日
TemporalType.TIME 只有小時分鐘秒
TemporalType.TIMESTAMP 有年月日小時分鐘秒
2.一對多(多對一)
@OneToMany
@ManyToOne
3.級聯
@Cascade
八、Hibernate檢索方式概述
Hibernate提供以下5種檢索對象方式:
1 導航對象圖檢索方式,根據已加載的對象導航到其它對象
2.OID檢索方式,按照對象的OID來檢索對象
3.HQL檢索方式,使用面向對象的HQL查詢語言
4.QBC檢索方式,使用QBC(Query by Criteria)API來檢索對象,這種API封裝基於字符串形式的查詢語句,提供了更加面向對象的查詢接口
5.本地SQL檢索方式,使用本地數據庫的SQL查詢語句
九、Hibernate事務管理
1.Hibernate事務管理級別
xxx.hbm.xml配置事務管理

<property name="hibernate.connection.isolation">4</property>

1 代表的事務隔離級別為 READ UNCOMMITTED
2 代表的事務隔離級別為 READ COMMITTED
4 代表的事務隔離級別為 REPEATABLE READ
8 代表的事務隔離級別為 SERIALIZABLE
EAD_UNCOMMITED 讀取未提交,它引發所有的隔離問題
READ_COMMITTED 讀已提交,阻止臟讀,可能發生不可重復讀與虛讀.
REPEATABLE_READ 重復讀 阻止臟讀,不可重復讀 可能發生虛讀
SERIALIZABLE 串行化 解決所有問題 不允許兩個事務,同時操作一個目標數據。 (效率低下)
ORACLE 默認的是事務隔離級別 READ_COMMITTED
MYSQL 默認的事務隔離級別 REPEATABLE_READ
2. Hibernate中session管理
Hibernate提供了三種管理session的方式:
(1)Session 對象的生命周期與本地線程綁定(ThreadLocal)
(2)Session 對象的生命周期與 JTA 事務綁定(分布式事務管理)
(3)Hibernate 委托程序來管理 Session 的生命周期

Hibernate基礎知識詳解