RSS
热门关键字:
当前位置 : 主页>编程开发>软件工程>列表

Hibernate对多表关联查询

来源:我要研发网 作者: 时间:1970-01-01 点击:



  由于公司项目需要,我对Hibernate对多表关联查询研究了一下,现总结如下,供朋友参考。 字串1

  一、 Hibernate简介Hibernate是一个JDO工具。它工作原理是通过文件(一般有两种:xml文件和properties文件)把值对象和数据库表之间建立起一个映射关系。这样,我们只需要通过操作这些值对象和Hibernate提供一些基本类,就可以达到使用数据库。例如,使用Hibernate查询,可以直接返回包含某个值对象列表(List),而不必向传统JDBC访问方式一样把结果集数据逐个装载到一个值对象中,为编码工作节约了大量时间。Hibernate提供HQL是一种类SQL语言,它和EJBQL一样都是提供对象化数据库查询方式,但HQL在功能和使用方式上都非常接近于标准SQL. 字串5

  二、 Hibernate与JDBC区别Hibernate与JDBC主要区别如下: 字串2

  1、 Hibernate是JDBC轻量级对象封装,它是一个独立对象持久层框架,和App Server,和EJB没有什么必然联系。Hibernate可以用在任何JDBC可以使用场合,从某种意义上来说,Hibernate在任何场合下取代JDBC.

字串1

  2、 Hibernate是一个和JDBC密切关联框架,所以Hibernate兼容性和JDBC驱动,和数据库都有一定关系,但是和使用它Java程序,和App Server没有任何关系,也不存在兼容性问题。

字串6

  3、 Hibernate是做为JDBC替代者出现,不能用来直接和Entity Bean做对比。 字串7

  三、 Hibernate 进行多表关联查询Hibernate对多个表进行查询时,查询结果是多个表笛卡尔积,或者称为“交叉”连接。 例如:from Student, Book from Student as stu, Book as boo from Student stu, Book boo注意:让查询中Student和Book均是表student和book对应类名,它名字一定要和类名字相同,包括字母大小写。别名应该服从首字母小写规则是一个习惯,这和Java对局部变量命名规范是一致

字串4

  下面列举一个完整例子来说明Hibernate对多个表进行关联查询(其中粗体是我们要特别注意地方,相应表tBookInfo和BookSelection结构和其对应hbm.xml、class文件就不一一列举了,有需要详细了解朋友,请联系我): 字串1

String sTest = "from tBookInfo book, BookSelection sel where book.id = sel.bookId";
Collection result = new ArrayList();
Transaction tx = null;
try {
 Session session = HibernateUtil.currentSession();
 tx = session.beginTransaction();
 Query query = session.createQuery(sql);
 result = query.list();
 tx.commit();
} catch (Exception e) {
 throw e;
} finally {
 HibernateUtil.closeSession();
}
ArrayList sList = (ArrayList) result;
Iterator iterator1 = sList.iterator();
while (iterator1.hasNext()) {
 Object[] o = (Object[]) iterator1.next();
 tBookInfo bookInfo = (tBookInfo) o[0];
 BookSelection bookSelect = (BookSelection) o[1];
 System.out.println("BookInfo-Title: " bookInfo.getTitle());
 System.out.println("BookSelection-BookSelectionId: " bookSelect.getId());
}
字串4

最新评论共有 0 位网友发表了评论
发表评论
评论内容:不能超过250字,需审核,请自觉遵守互联网相关政策法规。
用户名: 密码:
匿名?
注册
相关文章