真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Hibernate多表關(guān)聯(lián)查詢怎么實現(xiàn)

本篇內(nèi)容介紹了“Hibernate多表關(guān)聯(lián)查詢怎么實現(xiàn)”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)建站專業(yè)IDC數(shù)據(jù)服務(wù)器托管提供商,專業(yè)提供成都服務(wù)器托管,服務(wù)器租用,光華機房服務(wù)器托管光華機房服務(wù)器托管,成都多線服務(wù)器托管等服務(wù)器托管服務(wù)。

一、Hibernate簡介Hibernate是一個JDO工具

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

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

1、 Hibernate是JDBC的輕量級的對象封裝,它是一個獨立的對象持久層框架,和App Server,和EJB沒有什么必然的聯(lián)系。Hibernate可以用在任何JDBC可以使用的場合,從某種意義上來說,Hibernate在任何場合下取代JDBC.

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

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

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

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

下面列舉一個完整的例子來說明Hibernate多表關(guān)聯(lián)查詢(其中粗體是我們要特別注意的地方,相應(yīng)表tBookInfo和BookSelection的結(jié)構(gòu)和其對應(yīng)的hbm.xml、class文件就不一一列舉了,有需要詳細了解的朋友,請聯(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());  

“Hibernate多表關(guān)聯(lián)查詢怎么實現(xiàn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!


網(wǎng)頁名稱:Hibernate多表關(guān)聯(lián)查詢怎么實現(xiàn)
本文來源:http://weahome.cn/article/pshsjj.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部