简述Hibernate在HQL中查询实例

开发 后端
Hibernate查询包括支持字符串方式参数传递查询、传递参数查询、支持多参数传递、调用数据库里面的函数、直接支持sql查询、进行导航查询、分页查询。

我们学习Hibernate查询是知道HQL支持条件查询,分为好多方面,这里我们就具体Hibernate查询用实例来加以说明,希望对读者的学习带来帮助。

1、支持字符串方式参数传递查询:

例子:

  1. List students = session.createQuery("select s.id,s.name from Student s where s.name like '%1' ").list();  
  2.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  3.                 Object[] o = (Object[])iter.next();  
  4.                 System.out.println(o[0]+","+o[1]);  
  5.             } 

由于,涉及到多个属性查询,所以返回的是Object数组类型。

2、支持类似于PrepareStatement方式的?传递参数查询

例子:

  1. List students = session.createQuery("select s.id,s.name from Student s where s.name like :goodname ")  
  2.                                                 .setParameter("goodname", "%1%").list();  
  3.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  4.                Object[] o = (Object[])iter.next();  
  5.                System.out.println(o[0]+","+o[1]);  
  6.            } 

要设置参数从0开始,见第2行。

3、去变量方式参数传递

例子:

  1. List students = session.createQuery("select s.id,s.name from Student s where s.name like :goodname ")  
  2.                                                 .setParameter("goodname", "%1%").list();  
  3.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  4.                Object[] o = (Object[])iter.next();  
  5.                 System.out.println(o[0]+","+o[1]);  
  6.            } 

这个跟2中的相似,只是多了参数可以归为一类。

4、支持多参数传递

例子:

  1. List students = session.createQuery("select s.id, s.name from Student s where s.id in(:myids)")  
  2.             .setParameterList("myids", new Object[]{1, 2, 3, 4, 5,32,13,14})  
  3.                 .list();  
  4.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  5.                 Object[] o = (Object[])iter.next();  
  6.                 System.out.println(o[0]+","+o[1]);  
  7.             } 

注意调用方法是setParameterList。

5、调用数据库里面的函数

例子:

  1. List students = session.createQuery("select s.id, s.name from Student s where date_format(s.createTime, '%Y-%m')=?")  
  2.            .setParameter(0, "2008-10")  
  3.                 .list();  
  4.            for (Iterator iter=students.iterator(); iter.hasNext();) {  
  5.                 Object[] o = (Object[])iter.next();  
  6.                System.out.println(o[0]+","+o[1]);  
  7.            } 

数据库函数date_format。

6、直接支持sql查询

例子:

  1. List students = session.createSQLQuery("select *from t_student").list();  
  2.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  3.                Object[] o = (Object[])iter.next();  
  4.                 System.out.println(o[0]+","+o[1]);  
  5.            } 

只需要调用session里面的createSQLQuery方法即可。

7、进行导航查询

例子:

  1. List students = session.createQuery("select s.name from Student s where s.classes.name like '%1%'").list();  
  2.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  3.                String s = (String)iter.next();  
  4.                 System.out.println(s);  
  5.             } 

这种查询很方便。

8、分页查询

例子:

  1. List students = session.createQuery("from Student").setFirstResult(0).setMaxResults(3).list();  
  2.             for (Iterator iter=students.iterator(); iter.hasNext();) {  
  3.                 Student student = (Student)iter.next();  
  4.                 System.out.println(student.getName());  
  5.             } 

这是很简单的分页查询,分页查询实现比这个复杂多了,分页查询采用的相当于数据库里面的 limit ,来限制一次查询显示的条数。

注:还有一些其他就不一一列举了,Hibernate查询在Hibernate的使用中HQL查询语言如果用得好,会给工作带来比较高的效率,比较重要,而且还有一个查询效率的问题,这涉及到缓存等方面,以后会更新这方面的文章。

【编辑推荐】

  1. 简述Hibernate中加载并存储对象
  2. Hibernate传播性持久化攻略
  3. 深入了解Hibernate自动状态检测
  4. 教你如何在Hibernate中实例化集合和代理
  5. Hinerbate单端关联代理颇析
责任编辑:仲衡 来源: blogjava
相关推荐

2009-06-18 09:14:08

Hibernate H

2009-09-23 18:05:48

2009-06-29 18:26:46

HibernateHQL查询

2009-09-23 09:16:25

Hibernate复合

2009-09-24 10:35:10

Hibernate查询

2009-06-12 15:32:01

Hibernate H

2009-09-24 10:15:37

Hibernate查询

2009-09-22 08:39:59

Hibernate F

2009-06-26 16:09:21

Hibernate查询HQL

2014-05-12 10:37:41

2009-09-24 11:17:32

Hibernate查询

2009-09-29 16:41:58

Hibernate S

2009-06-30 16:55:19

2009-09-27 14:56:22

Hibernate H

2009-09-25 12:31:13

Hibernate映射

2009-09-28 13:45:59

Hibernate历史

2009-09-29 17:22:30

Hibernate S

2009-09-23 15:25:08

Hibernate 3

2009-09-29 15:58:22

Hibernate映射

2009-09-29 10:37:29

Hibernate持久
点赞
收藏

51CTO技术栈公众号