Hibernate(two)

//////////2016-12-14 ~ 2016-12-15///////////

int study_data(){

配置實(shí)體映射:

1.xml:

配置文件名字:類名.hbm.xml

<hibernate-mapping>

? ? <class name="className" table="tableName">

? ? ? ? <id name="類屬性名" column="主鍵名" />

? ? ? ? <property name="屬性名" column="字段名" />

? ? ? ? ...

? ? </class>

</hibernate-mapping>

2.annotation:

@Entity ? ?//注解Entity表示該類納入Hibernate管理旭绒,能夠被持久化养筒,加在實(shí)體類前面

@Table(name="tableName") ? ?//指定該實(shí)體類對應(yīng)的數(shù)據(jù)庫表名撇吞,加在實(shí)體類前面

@Id ? ?//指定該列為主鍵曹锨。

@Column(name="變量名") ? ?//指定變量對應(yīng)的數(shù)據(jù)庫表的列為"變量名"

hibernate主鍵策略

assigned - 主鍵由外部程序負(fù)責(zé)生成

increment - 由hibernate從數(shù)據(jù)庫中取出主鍵的最大值获枝,每次增量為1,在內(nèi)存中生成主鍵

hilo - 高地位方式荐糜,最常用的一種生成方式疙咸。需要一張額外的表保存hi的值

seqhilo - 將hilo中的數(shù)據(jù)表換成了序列sequence,適用于支持sequence的數(shù)據(jù)庫(mysql中不支持sequence)

sequence - 采用數(shù)據(jù)庫提供的sequence機(jī)制生成主鍵媳友,需要數(shù)據(jù)庫支持sequence

identity - 由數(shù)據(jù)庫自己生成斯议,但這個(gè)主鍵必須設(shè)置為自增長

native - 由hibernate根據(jù)使用的數(shù)據(jù)庫自行判斷采用identity,hilo醇锚,sequence其中一種作為主鍵生成方式

uuid - 指在一臺(tái)機(jī)器上生成的數(shù)字

guid - 全球唯一標(biāo)識(shí)符

foreign - 使用另外一個(gè)相關(guān)聯(lián)的對象的主鍵作為該對象的主鍵哼御。主要用于一對一關(guān)系中

select - 使用觸發(fā)器生成主鍵坯临,很少用

Hibernate實(shí)體查詢

session.get(class,id):

1.session緩存中查找是否存在id對應(yīng)的Object

2.二級(jí)緩存中查找是否存在id對應(yīng)的Object

3.數(shù)據(jù)庫查找,若不存在則返回null

session.load(class,id):

lazy load模式:

1.session緩存查找是否存在id對應(yīng)的Object

2.不存在則返回實(shí)體相應(yīng)的代理對象(沒有實(shí)體數(shù)據(jù))

3.當(dāng)使用該代理對象時(shí)恋昼,再查詢二級(jí)緩存和數(shù)據(jù)庫(沒找到時(shí)報(bào)錯(cuò)看靠,而不是返回null)

非lazy load模式:和get方法一致。

session.find(class,id):

與get方法相似液肌,已不建議使用

HQL查詢

HQL(Hibernate Query Language)的語法和SQL很相似挟炬,但是HQL是一種面向?qū)ο蟮牟樵冋Z句,它的操作對象是類嗦哆、實(shí)例谤祖、屬性等,而SQL的操作對象是數(shù)據(jù)表老速、列等數(shù)據(jù)庫對象粥喜。

HQL查詢依賴于Query類,每一個(gè)Query實(shí)例對應(yīng)一個(gè)查詢對象橘券,它的執(zhí)行是通過Session的createQuery()方法來獲得的额湘。

Query:

session.creatQuery(HQL)

session.creatQuery(HQL,Class)

session.creatNativeQuery(SQL)

session.creatNativeQuery(SQL,Class)

執(zhí)行HQL查詢的步驟:

1、獲得Hibernate?Session對象

2旁舰、編寫HQL語句

3锋华、調(diào)用Session的createQuery方法創(chuàng)建查詢對象

4、如果HQL語句包含參數(shù)箭窜,則調(diào)用Query的setXxx方法為參數(shù)賦值

5毯焕、調(diào)用Query對象的list等方法返回查詢結(jié)果。

特點(diǎn):

關(guān)鍵字不區(qū)分大小寫

持久類名稱及屬性區(qū)分大小寫

支持占位符(:name)

from子句绽快,select子句

Hibernate實(shí)體操作:

實(shí)體狀態(tài):

1.瞬時(shí)/臨時(shí)狀態(tài)(transient):對象不存在數(shù)據(jù)庫以及session緩存當(dāng)中

2.持久化狀態(tài)(persistent):對象存在于數(shù)據(jù)庫以及session緩存當(dāng)中

3.離線/游離狀態(tài)(detached):對象存在與數(shù)據(jù)庫但不存在與session緩存當(dāng)中芥丧,即未被session托管

狀態(tài)轉(zhuǎn)化:

new一個(gè)實(shí)體時(shí)變?yōu)榕R時(shí)狀態(tài)

臨時(shí)狀態(tài)->持久化狀態(tài):save(obeject)紧阔,saveOrUpdate(object)

持久化狀態(tài)->臨時(shí)狀態(tài):delete(object)

持久化狀態(tài)->游離狀態(tài):avict(object)坊罢,close(object),clear(object)

游離狀態(tài)->持久化狀態(tài):update(object)擅耽,saveOrUpdate(object),lock(object)

游離狀態(tài)->臨時(shí)狀態(tài):delete(object)

Hibernate事務(wù)管理:

Transaction tx = session.beginTransaction()等同于connection.setAutoCommit(false)

tx.commit()等同于connection.commit()

tx.rollback()等同于connection.rollback()

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末活孩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子乖仇,更是在濱河造成了極大的恐慌憾儒,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件乃沙,死亡現(xiàn)場離奇詭異起趾,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)警儒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門训裆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來眶根,“玉大人,你說我怎么就攤上這事边琉∈舭伲” “怎么了?”我有些...
    開封第一講書人閱讀 153,220評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵变姨,是天一觀的道長族扰。 經(jīng)常有香客問我,道長定欧,這世上最難降的妖魔是什么渔呵? 我笑而不...
    開封第一講書人閱讀 55,416評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮忧额,結(jié)果婚禮上厘肮,老公的妹妹穿的比我還像新娘。我一直安慰自己睦番,他們只是感情好类茂,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著托嚣,像睡著了一般巩检。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上示启,一...
    開封第一講書人閱讀 49,144評(píng)論 1 285
  • 那天兢哭,我揣著相機(jī)與錄音,去河邊找鬼夫嗓。 笑死迟螺,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的舍咖。 我是一名探鬼主播矩父,決...
    沈念sama閱讀 38,432評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼排霉!你這毒婦竟也來了窍株?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,088評(píng)論 0 261
  • 序言:老撾萬榮一對情侶失蹤攻柠,失蹤者是張志新(化名)和其女友劉穎球订,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體瑰钮,經(jīng)...
    沈念sama閱讀 43,586評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡冒滩,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了浪谴。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片开睡。...
    茶點(diǎn)故事閱讀 38,137評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡祈搜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出士八,到底是詐尸還是另有隱情容燕,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評(píng)論 4 324
  • 正文 年R本政府宣布婚度,位于F島的核電站蘸秘,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蝗茁。R本人自食惡果不足惜醋虏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望哮翘。 院中可真熱鬧颈嚼,春花似錦、人聲如沸饭寺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽艰匙。三九已至限煞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間员凝,已是汗流浹背署驻。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評(píng)論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留健霹,地道東北人旺上。 一個(gè)月前我還...
    沈念sama閱讀 45,595評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像糖埋,于是被迫代替她去往敵國和親宣吱。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • Hibernate是一個(gè)開放源代碼的對象關(guān)系映射框架阶捆,它對JDBC進(jìn)行了非常輕量級(jí)的對象封裝凌节,它將POJO與數(shù)據(jù)庫...
    蘭緣小妖閱讀 1,195評(píng)論 1 18
  • Hibernate: 一個(gè)持久化框架 一個(gè)ORM框架 加載:根據(jù)特定的OID,把一個(gè)對象從數(shù)據(jù)庫加載到內(nèi)存中OID...
    JHMichael閱讀 1,958評(píng)論 0 27
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法钦听,類相關(guān)的語法洒试,內(nèi)部類的語法,繼承相關(guān)的語法朴上,異常的語法垒棋,線程的語...
    子非魚_t_閱讀 31,587評(píng)論 18 399
  • 本文包括:1、Hibernate的持久化類2痪宰、Hibernate 持久化對象的三個(gè)狀態(tài)(難點(diǎn))3叼架、Hibernat...
    廖少少閱讀 1,436評(píng)論 0 13
  • 1.如何判斷一個(gè)元素是否出現(xiàn)在窗口可視范圍(瀏覽器的上邊緣和下邊緣之間畔裕,肉眼可視)。寫一個(gè)函數(shù) isVisible...
    Rising_suns閱讀 289評(píng)論 0 0