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