由于公司项目
需要,我对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.
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对局部变量
命名规范是一致
。
下面列举一个完整
例子来说明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 ![我要研发网[www.51dev.com]](/templets/images/toplogo.gif)
