自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

概括Hibernate多表關(guān)聯(lián)查詢

開(kāi)發(fā) 后端
這里介紹進(jìn)行Hibernate多表關(guān)聯(lián)查詢時(shí),查詢結(jié)果是多個(gè)表的笛卡爾積,或者稱為“交叉”連接。包括介紹Hibernate與JDBC的區(qū)別等方面。

本文向大家介紹Hibernate多表關(guān)聯(lián)查詢,可能好多人還不了解Hibernate多表關(guān)聯(lián)查詢,沒(méi)有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。

一、Hibernate簡(jiǎn)介Hibernate是一個(gè)JDO工具

它的工作原理是通過(guò)文件(一般有兩種:xml文件和properties文件)把值對(duì)象和數(shù)據(jù)庫(kù)表之間建立起一個(gè)映射關(guān)系。這樣,我們只需要通過(guò)操作這些值對(duì)象和Hibernate提供的一些基本類,就可以達(dá)到使用數(shù)據(jù)庫(kù)的目的。例如,使用Hibernate的查詢,可以直接返回包含某個(gè)值對(duì)象的列表(List),而不必向傳統(tǒng)的JDBC訪問(wèn)方式一樣把結(jié)果集的數(shù)據(jù)逐個(gè)裝載到一個(gè)值對(duì)象中,為編碼工作節(jié)約了大量的時(shí)間。Hibernate提供的HQL是一種類SQL語(yǔ)言,它和EJBQL一樣都是提供對(duì)象化的數(shù)據(jù)庫(kù)查詢方式,但HQL在功能和使用方式上都非常接近于標(biāo)準(zhǔn)的SQL.

二、Hibernate與JDBC的區(qū)別

1、 Hibernate是JDBC的輕量級(jí)的對(duì)象封裝,它是一個(gè)獨(dú)立的對(duì)象持久層框架,和App Server,和EJB沒(méi)有什么必然的聯(lián)系。Hibernate可以用在任何JDBC可以使用的場(chǎng)合,從某種意義上來(lái)說(shuō),Hibernate在任何場(chǎng)合下取代JDBC.

2、 Hibernate是一個(gè)和JDBC密切關(guān)聯(lián)的框架,所以Hibernate的兼容性和JDBC驅(qū)動(dòng),和數(shù)據(jù)庫(kù)都有一定的關(guān)系,但是和使用它的Java程序,和App Server沒(méi)有任何關(guān)系,也不存在兼容性問(wèn)題。

3、 Hibernate是做為JDBC的替代者出現(xiàn)的,不能用來(lái)直接和Entity Bean做對(duì)比。

三、Hibernate多表關(guān)聯(lián)查詢

進(jìn)行Hibernate多表關(guān)聯(lián)查詢時(shí),查詢結(jié)果是多個(gè)表的笛卡爾積,或者稱為“交叉”連接。 例如:from Student, Book from Student as stu, Book as boo from Student stu, Book boo注意:讓查詢中的Student和Book均是表student和book對(duì)應(yīng)的類名,它的名字一定要和類的名字相同,包括字母的大小寫(xiě)。別名應(yīng)該服從首字母小寫(xiě)的規(guī)則是一個(gè)好習(xí)慣,這和Java對(duì)局部變量的命名規(guī)范是一致的。

下面列舉一個(gè)完整的例子來(lái)說(shuō)明Hibernate多表關(guān)聯(lián)查詢(其中粗體是我們要特別注意的地方,相應(yīng)表tBookInfo和BookSelection的結(jié)構(gòu)和其對(duì)應(yīng)的hbm.xml、class文件就不一一列舉了,有需要詳細(xì)了解的朋友,請(qǐng)聯(lián)系我):

  1. String sTest = "from tBookInfo book, 
    BookSelection sel where book.id = sel.bookId"
    ;  
  2. Collection result = new ArrayList();  
  3. Transaction tx = null;  
  4. try {  
  5. Session session = HibernateUtil.currentSession();  
  6. tx = session.beginTransaction();  
  7. Query query = session.createQuery(sql);  
  8. result = query.list();  
  9. tx.commit();  
  10. }  
  11. catch (Exception e) {  
  12. throw e;  
  13. }  
  14. finally {  
  15. HibernateUtil.closeSession();  
  16. }  
  17. ArrayList sList = (ArrayList) result;  
  18. Iterator iterator1 = sList.iterator();  
  19. while (iterator1.hasNext()) {  
  20. Object[] o = (Object[]) iterator1.next();  
  21. tBookInfo bookInfo = (tBookInfo) o[0];  
  22. BookSelection bookSelect = (BookSelection) o[1];  
  23. System.out.println("BookInfo-Title: " + bookInfo.getTitle());  
  24. System.out.println("BookSelection-BookSelectionId: " + bookSelect.getId());  

【編輯推薦】

  1. Hibernate類庫(kù)簡(jiǎn)單描述
  2. 淺析Hibernate延遲加載
  3. Spring Hibernate簡(jiǎn)單討論
  4. 介紹Hibernate版本的更新
  5. 簡(jiǎn)單講述Hibernate實(shí)例
責(zé)任編輯:佚名 來(lái)源: IT168
相關(guān)推薦

2009-09-29 16:29:40

Hibernate查詢

2021-09-02 18:36:35

SQLWhereOn

2009-09-23 18:05:48

2009-06-18 13:58:06

Hibernate多表Hibernate

2017-07-25 15:35:07

MysqlMysql優(yōu)化LIMIT分頁(yè)

2009-09-22 15:26:30

Hibernate多表

2020-11-05 10:59:45

Mybatis

2012-06-05 02:20:24

JPAJava查詢語(yǔ)言

2009-09-24 09:25:10

Hibernate批量

2009-09-25 15:15:54

Hibernate檢索

2009-09-22 13:31:28

Hibernate C

2009-09-28 15:24:38

Hibernate V

2009-09-21 16:56:14

Hibernateibatis

2009-09-28 17:27:27

Hibernate A

2009-09-22 17:55:51

Spring Hibe

2009-09-22 09:31:15

Hibernate主鍵

2009-09-27 14:33:01

Hibernate批量

2010-06-03 09:24:46

Oracle

2009-09-28 09:56:53

Hibernate屬性

2009-09-22 13:12:25

Hibernateibatis
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)