Hibernate核心類和接口的詳細(xì)介紹
一、hiobernate核心類和接口預(yù)覽圖

二、hibernate.properties
這個(gè)文件是以前老版本使用的 類似于hibernate.cfg.xml文件;作用和hibernate.cfg.xml一致.
三、hibernate.cfg.xml
(1)詳細(xì)介紹
①該文件主要用于指定各個(gè)參數(shù),是hibernate核心文件
②默認(rèn)放在src目錄下,也可以放在別的目錄下。
③指定連接數(shù)據(jù)庫的驅(qū)動(dòng)、用戶名、密碼、url、連接池..
④指定對(duì)象關(guān)系映射文件的位置.
⑤也可使用hibernate.properties文件來替代該文件.(推薦使用hibernate.cfg.xml)。
(2)配置文件模板
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- hibernate的核心配置文件 -->
<hibernate-configuration>
<session-factory>
<!--配置使用的driver -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.username">root</property>
<property name="connection.password">xu827928</property>
<property name="connection.url">jdbc:mysql://127.0.0.1:3306/hbmtest</property>
<!-- 配置dialect方言,明確告訴hibernate連接的是哪種數(shù)據(jù)庫 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 顯示出對(duì)應(yīng)sql語句 -->
<property name="show_sql">true</property>
<!-- 格式化輸出sql語句 -->
<property name="format_sql">true</property>
<!--讓hibernate幫我們創(chuàng)建 一張表 -->
<!--
update:如果沒有表則創(chuàng)建表 如果有表 則看表結(jié)構(gòu)是否變化 如果有變化則會(huì)創(chuàng)建新表
如果沒有則添加
create:每次都創(chuàng)建新的數(shù)據(jù)庫
-->
<!-- <property name="hbm2ddl.auto">create</property> -->
<property name="hbm2ddl.auto">update</property>
<!-- 指定管理對(duì)象映射文件 -->
<mapping resource="com/lc/domain/Employee.hbm.xml"></mapping>
</session-factory>
</hibernate-configuration>
四、*.hbm.xml
(1)對(duì)象關(guān)系映射文件(*.hbm.xml)
①該文件主要作用是建立表和類的映射關(guān)系,是不可或缺的重要文件.
②一般放在其映射的類同一個(gè)目錄下,但不是必須的。
③命名方式一般是 類名.hbm.xml,但不是必須的。
④示意圖:

(2)配置文件模板
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
'-//Hibernate/Hibernate Mapping DTD 3.0//EN'
'http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd'>
<!-- 這是映射Employee表的hibernate -->
<!-- 該文件用于配置domain對(duì)象和表的映射關(guān)系 -->
<hibernate-mapping package="com.lc.domain">
<class name="Employee" table="employee">
<!-- id元素用于指定主鍵屬性 -->
<id name="id" column="id" type="java.lang.Integer">
<generator class="increment" />
</id>
<!-- 對(duì)其他屬性的配置 -->
<property name="name" type="java.lang.String">
<column name="name" not-null="false" />
</property>
<property name="email" type="java.lang.String">
<column name="email" not-null="false" />
</property>
<property name="hiredate" type="java.util.Date">
<column name="hiredate" not-null="false" />
</property>
</class>
</hibernate-mapping>
五、Configuration類
(1)詳細(xì)介紹
①負(fù)責(zé)管理hibernate的配置信息
②讀取hibernate.cfg.xml
③加載hibernate.cfg.xml配置文件中配置的驅(qū)動(dòng),url,用戶名,密碼,連接池.
④管理 *.hbm.xml對(duì)象關(guān)系文件.
(2)示意代碼:
Configuration cf=new Configuration().configure();
六、SessionFactory(會(huì)話工廠)接口
(1)詳細(xì)介紹
①緩存sql語句和某些數(shù)據(jù)
②在應(yīng)用程序初始化的時(shí)候創(chuàng)建,是一個(gè)重量級(jí)的類(吃內(nèi)存),一般用單例模式保證一個(gè)應(yīng)用中只需要一個(gè) SessionFactory實(shí)例.
③如果某個(gè)應(yīng)用訪問多個(gè)數(shù)據(jù)庫,則要?jiǎng)?chuàng)建多個(gè)會(huì)話工廠實(shí)例,一般是一個(gè)數(shù)據(jù)庫一個(gè)會(huì)話工廠實(shí)例.
④通過SessionFactory接口可以獲得Session(會(huì)話)實(shí)例.

(2)示意代碼:
Configuration cf=new Configuration().configure(); SessionFactory sf=cf.buildSessionFactory(); Session s=sf.getCurrentSession(); //或者是: Session s=sf.openSession();
七、Session(會(huì)話)接口
(1)接口介紹
①Session一個(gè)實(shí)例代表與數(shù)據(jù)庫的一次操作(當(dāng)然一次操作可以是crud組合)
②Session實(shí)例通過SessionFactory獲取,用完需要關(guān)閉。
③Session是線程不同步的(不安全),因此要保證在同一線程中使用,可以用getCurrentSessiong()。
④Session可以看做是持久化管理器,它是與持久化操作相關(guān)的接口
(2)示意代碼:
Configuration cf=new Configuration().configure(); SessionFactory sf=cf.buildSessionFactory(); Session s=sf.getCurrentSession(); //或者是: Session s=sf.openSession();
(3)Session(會(huì)話)接口的幾個(gè)重要方法
Session一般以對(duì)象的形式來操作,這里
給大家演示一下吧!(請(qǐng)參考文檔)
①保存一個(gè)對(duì)象(記錄)—save方法
②刪除一個(gè)對(duì)象(記錄)—delete方法
③查詢一個(gè)對(duì)象(記錄)—get/load方法
④修改一個(gè)對(duì)象(記錄)—update方法
(4)get()和load()區(qū)別
1、get()方法直接返回實(shí)體類,如果查不到數(shù)據(jù)則返回null。load()會(huì)返回一個(gè)實(shí)體代理對(duì)象(當(dāng)前這個(gè)對(duì)象可以自動(dòng)轉(zhuǎn)化為實(shí)體對(duì)象),但當(dāng)代理對(duì)象被調(diào)用時(shí),如果沒有數(shù)據(jù)不存在,就會(huì)拋出個(gè)org.hibernate.ObjectNotFoundException異常
2.load先到緩存(session緩存/二級(jí)緩存)中去查,如果沒有則返回一個(gè)代理對(duì)象(不馬上到DB中去找),等后面使用這個(gè)代理對(duì)象操作的時(shí)候,才到DB中查詢,這就是我們常說的 load在默認(rèn)情況下支持延遲加載(lazy)
3. get先到緩存(session緩存/二級(jí)緩存)中去查,如果沒有就到DB中去查(即馬上發(fā)出sql)。總之,如果你確定DB中有這個(gè)對(duì)象就用load(),不確定就用get()(這樣效率高)
load VS get
1. 如果查詢不到數(shù)據(jù),get 會(huì)返回 null,但是不會(huì)報(bào)錯(cuò), load 如果查詢不到數(shù)據(jù),則報(bào)錯(cuò)ObjectNotFoundException
2. 使用get 去查詢數(shù)據(jù),(先到一級(jí)/二級(jí))會(huì)立即向db發(fā)出查詢請(qǐng)求(select ...), 如果你使用的是 load查詢數(shù)據(jù),(先到一級(jí)、二級(jí)))即使查詢到對(duì)象,返回的是一個(gè)代理對(duì)象,如果后面沒有使用查詢結(jié)果,它不會(huì)真的向數(shù)據(jù)庫發(fā)select ,當(dāng)程序員使用查詢結(jié)果的時(shí)候才真的發(fā)出select ,這個(gè)現(xiàn)象我們稱為懶加載(lazy)
3. 通過修改配置文件(*.hbm.xml文件),我們可以取消懶加載
<class name="Employee" lazy="false" table="employee">
4. 如何選擇使用哪個(gè): 如果你確定DB中有這個(gè)對(duì)象就用load(),不確定就用get()(這樣效率高)
(5)openSession()和 getCurrentSession()區(qū)別
①采用getCurrentSession()創(chuàng)建的session會(huì)綁定到當(dāng)前線程中,而采用openSession()創(chuàng)建的session則不會(huì)
②采用getCurrentSession()創(chuàng)建的session在commit或rollback時(shí)會(huì)自動(dòng)關(guān)閉,而采用openSession()創(chuàng)建的session必須手動(dòng)關(guān)閉.
③使用getCurrentSession()需要在hibernate.cfg.xml文件中加入
如下配置:
* 如果使用的是本地事務(wù)(jdbc事務(wù)) <property name="hibernate.current_session_context_class">thread</property> * 如果使用的是全局事務(wù)(jta事務(wù)) <property name="hibernate.current_session_context_class">jta</property>
(6) openSession()和 getCurrentSession()聯(lián)系
深入探討:
在 SessionFactory啟動(dòng)的時(shí)候,Hibernate 會(huì)根據(jù)配置創(chuàng)建相應(yīng)的 CurrentSessionContext,在getCurrentSession()被調(diào)用的時(shí)候,實(shí)際被執(zhí)行的方法是 CurrentSessionContext.currentSession()。
在currentSession()執(zhí)行時(shí),如果當(dāng)前Session為空,currentSession會(huì)調(diào)用SessionFactory的openSession。
(7)openSession()和 getCurrentSession()究竟選誰?
原則:
①如果需要在同一線程中,保證使用同一個(gè)Session則,使用getCurrentSession()
②如果在一個(gè)線程中,需要使用不同的Session,則使用opentSession()
(8)openSession()和 getCurrentSession()聯(lián)系,用ThreadLocal模式 (線程局部變量模式) 管理Session,代碼如下:
public class HibernateUtil {
public static final ThreadLocal session =new ThreadLocal();
public static final SessionFactory sessionFactory;
static {
try {
sessionFactory = new Configuration().configure().buildSessionFactory();
} catch (Throwable ex) {
throw new ExceptionInInitializerError(ex);
}
}
public static Session currentSession() throws HibernateException {
Session s = session.get();
if(s == null) {
s = sessionFactory.openSession();session.set(s);}
return s;}
public static void closeSession() throws HibernateException {
Session s = session.get();
if(s != null) { s.close();}
session.set(null); }}

八、Transaction(事務(wù))接口
(1)這里我們簡(jiǎn)單給大家說明一下什么是事務(wù)。
事務(wù)簡(jiǎn)單的說,就是一組對(duì)數(shù)據(jù)庫的操作集合,它們要么全部成功,要么全部失敗.這個(gè)可以保證數(shù)據(jù)的一致性,事務(wù)具有原子性。
①Transaction是底層的事物實(shí)現(xiàn)中抽象出來的接口
②可能是一個(gè)jdbc或者jta的事務(wù),這樣有利于hibernate在不同執(zhí)行環(huán)境的移植。
③hibernate要求顯示的調(diào)用事務(wù)(如果僅僅是查詢可以不調(diào)用.)
Transaction ts=s.beginTransaction(); ... ts.commit();s.close(); 發(fā)生異常需要ts.rollback()回滾.
(2)全局事務(wù)和本地事務(wù)
本地事務(wù):針對(duì)一個(gè)數(shù)據(jù)庫的事務(wù);(jabc事務(wù))
全部事務(wù):跨數(shù)據(jù)庫的事務(wù)(jta事務(wù));
如果要使用getCurrentSession的時(shí)候就需要在hibernate.cfg.xml文件中根據(jù)實(shí)際配置
* 如果使用的是本地事務(wù)(jdbc事務(wù)) <property name="hibernate.current_session_context_class">thread</property> * 如果使用的是全局事務(wù)(jta事務(wù)) <property name="hibernate.current_session_context_class">jta</property>
九、Query接口
(1)Query接口類型的對(duì)象可以對(duì)數(shù)據(jù)庫操作,它可以使用Hql,Qbc,Qbe和原生SQL(native Sql)對(duì)數(shù)據(jù)庫操作.官方推薦使用Hql語句。
十、 Criteria接口
Criteria接口也可用于面向?qū)ο蠓绞降牟樵?,關(guān)于它的具體用法我們
這里先不做介紹,簡(jiǎn)單看幾個(gè)案例.
最簡(jiǎn)單案例:返回50條記錄
Criteria crit = sess.createCriteria(Cat.class); crit.setMaxResults(50); List cats = crit.list();
限制結(jié)果集內(nèi)容
List cats = sess.createCriteria(Cat.class)
.add( Restrictions.like("name", "Fritz%") )
.add( Restrictions.between("weight", minWeight, maxWeight) )
.list();
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接
相關(guān)文章
mybatisplus自動(dòng)填充屬性值的實(shí)現(xiàn)步驟
MyBatis-Plus提供自動(dòng)填充的功能,幫助自定設(shè)置這些字段的值,提升開發(fā)效率,本文就來介紹一下如何使用,感興趣的可以了解一下2023-12-12
idea導(dǎo)入springboot項(xiàng)目沒有maven的解決
這篇文章主要介紹了idea導(dǎo)入springboot項(xiàng)目沒有maven的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
了解java架構(gòu)之微服務(wù)架構(gòu)—雪崩效應(yīng)
這篇文章主要介紹了了解java架構(gòu)之微服務(wù)架構(gòu)—雪崩效應(yīng),微服務(wù)化產(chǎn)品線,每一個(gè)服務(wù)專心于自己的業(yè)務(wù)邏輯,并對(duì)外提供相應(yīng)的接口,看上去似乎很明了,其實(shí)還有很多的東西需要考慮,,需要的朋友可以參考下2019-06-06
Java對(duì)象轉(zhuǎn)Json,關(guān)于@JSONField對(duì)象字段重命名和順序問題
這篇文章主要介紹了Java對(duì)象轉(zhuǎn)Json,關(guān)于@JSONField對(duì)象字段重命名和順序問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
spring?security?自定義Provider?如何實(shí)現(xiàn)多種認(rèn)證
這篇文章主要介紹了spring?security?自定義Provider實(shí)現(xiàn)多種認(rèn)證方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12
解決IDEA錯(cuò)誤 Cause: java.sql.SQLException: The server time zone
這篇文章主要介紹了解決IDEA錯(cuò)誤 Cause: java.sql.SQLException: The server time zone value的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
關(guān)于使用Mybatisplus自帶的selectById和insert方法時(shí)的一些問題
這篇文章主要介紹了關(guān)于使用Mybatisplus自帶的selectById和insert方法時(shí)的一些問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08

