Hibernate基礎知識詳解

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

      <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文件下的信息能夠配置mysql

<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
4、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;
5、Hibernate持久化類與 主鍵生成策略
    在 hbm.xml 中能夠設置的主鍵生成策略以下:
    主鍵生成器                                                描述
    increment                                                  代理主鍵。由 hibernate 維護一個變量,每次生成主鍵時自動以遞增。 問題:若是有多個應用訪問一個數據庫,因爲每一個應用維護本身                           的主鍵。此時主鍵可能衝突。建議不採用。
    identity                                                      代理主鍵。由底層數據庫生成表識符。條件是數據庫支持自動增加數據類型。 好比:mysql 的自增主鍵,oracle 不支持主鍵自動生成。                          若是數據庫支持自增建議採用。
    sequence                                                  代理主鍵。Hibernate 根據底層數據庫序列生成標識符。條件是數據庫支持序 列。好比 oracle 的序列。若是數據庫支持序列建議採用。
    native                                                        代理主鍵。根據底層數據庫對自動來選擇 identity、sequence、hilo因爲生成主鍵策略的控制權由 hibernate 控制,因此不建議採用。
    uuid                                                        代理主鍵。Hibernate 採用 128 位的 UUID 算法來生成標識符。該算法可以在網絡環境中生成惟一的字符串標識符。此策略能夠保證生                           成主鍵的惟一性,而且提供了最好的數據庫插入性能和數據庫平臺的無關性。建議採用。
    assigned                                                   天然主鍵。由 java 程序負責生成標識符。不建議採用。
6、Hibernate持久化對象狀態
    1. 瞬時態:也叫作臨時態或自由態,它通常指咱們new出來的對象,它不存在OID,與hibernate session無關聯,在數據庫中也無記錄。它使用
    完成後,會被jvm直接回收掉,它只是用於信息攜帶。
    簡單說:無OID與數據庫中的信息無關聯,不在 session 管理範圍內。
    2. 持久態:在 hibernate session 管理範圍內,它具備持久化標識OID它的特色,在事務未提交前一直是持久態,當它發生改變時,hibernate
    是能夠檢測到的。
    簡單說:有OID 由session管理,在數據庫中有可能有,也有可有沒有。
    3. 託管態:也叫作遊離態或離線態,它是指持久態對象失去了與session的關聯,託管態對象它存在OID,在數據庫中有可能存在,也有可能不
    存在。對於託管態對象,它發生改變時hibernet不能檢測到。
7、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
8、Hibernate檢索方式概述
    Hibernate提供如下5種檢索對象方式:
        1 導航對象圖檢索方式,根據已加載的對象導航到其它對象
        2.OID檢索方式,按照對象的OID來檢索對象
        3.HQL檢索方式,使用面向對象的HQL查詢語言
        4.QBC檢索方式,使用QBC(Query by Criteria)API來檢索對象,這種API封裝基於字符串形式的查詢語句,提供了更加面向對象的查詢接口
        5.本地SQL檢索方式,使用本地數據庫的SQL查詢語句
9、Hibernate事務管理
    1.Hibernate事務管理級別
        xxx.hbm.xml配置事務管理sql

<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 的生命週期數據庫

相關文章
相關標籤/搜索