Hibernate學習(Hibernate查詢方式)

Hibernate查詢方式

  1. 對象導航查詢
    (1)根據(jù)id查詢某個客戶惹悄,再查詢這個客戶里面所有的聯(lián)系人
  2. OID查詢
    (1)根據(jù)id查詢某一條記錄代虾,返回對象
  3. HQL查詢
    (1)Query對象饮潦,寫hql語句實現(xiàn)查詢
  4. QBC查詢
    (1)Criteria對象
  5. 本地sql查詢
    (1)SQLQuery對象银觅,使用普通sql實現(xiàn)查詢

對象導航查詢

  1. 查詢某個客戶里面所有聯(lián)系人過程首繁,使用對象導航實現(xiàn)
  2. 代碼
1.png

OID查詢

  1. 根據(jù)id查詢記錄
    (1)調(diào)用session里面的get方法實現(xiàn)
2.png

HQL查詢

  1. hql:hibernate query language坞琴,hibernate提供一種查詢語言哨查,hql語言和普通sql很相似,區(qū)別:普通sql操作數(shù)據(jù)庫表和字段剧辐,hql操作實體類和屬性
  2. 常用的hql語句
    (1)查詢所有: from 實體類名稱
    (2)條件查詢: from 實體類名稱 where 屬性名稱=?
    (3)排序查詢: from 實體類名稱 order by 實體類屬性名稱 asc/desc
  3. 使用hql查詢操作時候解恰,使用Query對象
    (1)創(chuàng)建Query對象,寫hql語句
    (2)調(diào)用query對象里面的方法得到結果

查詢所有

  1. 查詢所有客戶記錄
    (1)創(chuàng)建Query對象浙于,寫hql語句
    (2)調(diào)用query對象里面的方法得到結果
  2. 查詢所有: from 實體類名稱
1.png

條件查詢

  1. hql條件查詢語句寫法:
    (1) from 實體類名稱 where 實體類屬性名稱=? and實體類屬性名稱=?
    from 實體類名稱 where 實體類屬性名稱 like ?
  2. 代碼
2.png

模糊查詢

3.png

排序查詢

  1. hql排序語句寫法
    (1)from 實體類名稱 order by 實體類屬性名稱 asc/desc
4.png

分頁查詢

  1. mysql實現(xiàn)分頁
    (1)使用關鍵字 limit實現(xiàn)
SELECT * FROM S_MENU LIMIT 0,3;
  1. 在hql中實現(xiàn)分頁
    (1)在hql操作中护盈,在語句里面不能寫limit,hibernate的Query對象封裝兩個方法實現(xiàn)分頁操作
5.png

投影查詢

  1. 投影查詢:查詢不是所有字段值羞酗,而是部分字段的值
  2. 投影查詢hql語句寫法:
    (1)select 實體類屬性名稱1, 實體類屬性名稱2 from 實體類名稱
    (2)select 后面不能寫 * 腐宋,不支持的
  3. 具體實現(xiàn)
6.png

聚集函數(shù)使用

  1. 常用的聚集函數(shù)
    (1)count、sum檀轨、avg胸竞、max、min
  2. hql聚集函數(shù)語句寫法
    (1)查詢表記錄數(shù)
    select count(*) from 實體類名稱
7.png

QBC查詢

  1. 使用hql查詢需要寫hql語句實現(xiàn)参萄,但是使用qbc時候卫枝,不需要寫語句了,使用方法實現(xiàn)
  2. 使用qbc時候讹挎,操作實體類和屬性
  3. 使用qbc校赤,使用Criteria對象實現(xiàn)

查詢所有

  1. 創(chuàng)建Criteria對象
  2. 調(diào)用方法得到結果
8.png

條件查詢

沒有語句,使用封裝的方法實現(xiàn)

9.png
10.png

排序查詢

1.png

分頁查詢

2.png

開始位置計算公式: (當前頁-1)*每頁記錄數(shù)

統(tǒng)計查詢

離線查詢

  1. servlet調(diào)用service筒溃,service調(diào)用dao
    (1)在dao里面對數(shù)據(jù)庫crud操作
    (2)在dao里面使用hibernate框架马篮,使用hibernate框架時候,調(diào)用session里面的方法實現(xiàn)功能
4.png

HQL多表查詢

Mysql里面多表查詢

內(nèi)連接

5.png

左外連接

6.png

右外連接

7.png

HQL實現(xiàn)多表查詢

Hql多表查詢
(1)內(nèi)連接
(2)左外連接
(3)右外連接
(4)迫切內(nèi)連接
(5)迫切左外連接
#######HQL內(nèi)連接

  1. 內(nèi)連接查詢hql語句寫法:以客戶和聯(lián)系人為例
    (1)from Customer c inner join c.setLinkMan
8.png

返回list怜奖,list里面每部分是數(shù)組形式

  1. 演示迫切內(nèi)連接
    (1)迫切內(nèi)連接和內(nèi)連接底層實現(xiàn)一樣的
    (2)區(qū)別:使用內(nèi)連接返回list中每部分是數(shù)組浑测,迫切內(nèi)連接返回list每部分是對象
    (3)hql語句寫法
    from Customer c inner join fetch c.setLinkMan
9.png

#######HQL左外連接

  1. 左外連接hql語句:
    (1)from Customer c left outer join c.setLinkMan
    (2)迫切左外連接from Customer c left outer join fetch c.setLinkMan

  2. 左外連接返回list中每部分是數(shù)組,迫切左外連接返回list每部分是對象

  3. 右外連接hql語句:
    (1)from Customer c right outer join c.setLinkMan

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末歪玲,一起剝皮案震驚了整個濱河市迁央,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌滥崩,老刑警劉巖岖圈,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異夭委,居然都是意外死亡幅狮,警方通過查閱死者的電腦和手機募强,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來崇摄,“玉大人擎值,你說我怎么就攤上這事≈鹨郑” “怎么了鸠儿?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵,是天一觀的道長厕氨。 經(jīng)常有香客問我进每,道長,這世上最難降的妖魔是什么命斧? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任田晚,我火速辦了婚禮,結果婚禮上国葬,老公的妹妹穿的比我還像新娘贤徒。我一直安慰自己,他們只是感情好汇四,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布接奈。 她就那樣靜靜地躺著,像睡著了一般通孽。 火紅的嫁衣襯著肌膚如雪序宦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天背苦,我揣著相機與錄音互捌,去河邊找鬼。 笑死糠惫,一個胖子當著我的面吹牛疫剃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播硼讽,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼牲阁!你這毒婦竟也來了固阁?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤城菊,失蹤者是張志新(化名)和其女友劉穎备燃,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體凌唬,經(jīng)...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡并齐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片况褪。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡撕贞,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出测垛,到底是詐尸還是另有隱情捏膨,我是刑警寧澤,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布食侮,位于F島的核電站号涯,受9級特大地震影響,放射性物質發(fā)生泄漏锯七。R本人自食惡果不足惜链快,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望眉尸。 院中可真熱鬧久又,春花似錦、人聲如沸效五。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽畏妖。三九已至脉执,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間戒劫,已是汗流浹背半夷。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留迅细,地道東北人巫橄。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像茵典,于是被迫代替她去往敵國和親湘换。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348

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

  • 1. Java基礎部分 基礎部分的順序:基本語法统阿,類相關的語法彩倚,內(nèi)部類的語法,繼承相關的語法扶平,異常的語法帆离,線程的語...
    子非魚_t_閱讀 31,598評論 18 399
  • 本文包括:1、Hibernate 的查詢方式2结澄、HQL (Hibernate Query Language) 查詢...
    廖少少閱讀 2,651評論 0 15
  • 一 對象導航查詢 根據(jù)id查詢某個客戶哥谷,再查詢這個客戶里面所有的聯(lián)系人 查詢某個客戶里面所有聯(lián)系人過程岸夯,使用對象導...
    常威爆打來福閱讀 1,055評論 3 6
  • 一. Java基礎部分.................................................
    wy_sure閱讀 3,805評論 0 11
  • 有多少你我就有多少酸楚 不為別離 只是一下子溜走了所有經(jīng)過
    初四的心閱讀 241評論 2 5