Hibernate配备了一种非常强大的查询语言,就是HQL(hibernate query language),HQL看上去很像sql,但只是语法结构上相似,HQL是一种面向对象的查询,他可以理解继承,多态之类的概念.

  HQL区分大小写,sql语句关键字(如select ,from,where等)是不区分大小写的.

  假设我们现在有两张表,分别是Book,和Category:


            


需求1:查询Book表中所有的书名:

Session session=HibernateUtil.getSession();
//list()方法返回查询结果
//返回结果的类型是根据查询的列决定的,这里查询了name属性,因为name属性时String类型的,所有得到的是一个String类型的集合
List<String> list=session.createQuery("select name from Book").list();
for(String s:list){
System.out.println(s);
}

需求2:查询book表中所有的书名以及作者(查询多个列):

  方法1:

Session session=HibernateUtil.getSession();
//list()方法返回查询结果
//查询多个属性时返回的是数组集合,这里name,和author都是String类型,所以得到的是
List<Object[]> list = session.createQuery("select name,author from Book").list();
for(Object[] o:list){
System.out.println(o[0]+"----"+o[1]);
}

  方法2:

    1.在Book实体类中,新建一个构造函数,参数为name和author,(注意别忘了无参构造函数);

    2:

Session session=HibernateUtil.getSession();
//list()方法返回查询结果,返回的是Book类型的集合,
  //如果希望查询book所有列,hql语句直接写成 " from Book"就可以了.不能写成"select * from Book".
  //Hql语句中也可以使用别名,如果使用别名还可以写成,"select b from Book b";
  //下面语句 也可以写成这样:select new Book(b.name,b.author) from Book b;
   List<Book> list = session.createQuery("select new Book(name,author) from Book").list(); 

  for(Book book:list){ System.out.println(book); }

打印结果为:

Book [id=0, name=鹿鼎记, price=0.0, author=金庸, pubDate=null, category=null]
Book [id=0, name=斗破苍穹, price=0.0, author=土豆, pubDate=null, category=null]
Book [id=0, name=吞噬星空, price=0.0, author=番茄, pubDate=null, category=null]
Book [id=0, name=亮剑, price=0.0, author=都梁, pubDate=null, category=null]
Book [id=0, name=邪气凛然, price=0.0, author=耳根, pubDate=null, category=null]

需求3:条件查询,查询2<ID<5的所有Book:

 Session session=HibernateUtil.getSession();
//list()方法返回查询结果,这里返回的是Book类型的集合
//因为这里的id是int类型的,所以也可以将setParameter方法写成setInteger,第一个参数:0代表第一个问号
List<Book> list = session.createQuery("from Book where id < ? and id >?").setParameter(0, 5).setParameter(1, 2).list();
for(Book book:list){
System.out.println(book);
}

打印结果为:

Book [id=3, name=吞噬星空, price=27.35, author=番茄, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@67977199]
Book [id=4, name=亮剑, price=42.35, author=都梁, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@62d075cc]

需求4:查询Category为"玄幻类"的所有Book:

List<Category> list = session.createQuery("from Category where name = :name").setParameter("name", "玄幻类").list();
Set<Book> books = list.get(0).getBooks();
Iterator<Book> it = books.iterator();
while(it.hasNext()){
System.out.println(it.next());
}

  打印结果为:

Book [id=2, name=斗破苍穹, price=22.35, author=土豆, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@56446e79]
Book [id=3, name=吞噬星空, price=27.35, author=番茄, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@56446e79]

需求5:分页查询:

List<Book> list = session.createQuery("from Book")
.setFirstResult(0)//开始显示的记录下表((currentPage-1)*pageSize)
.setMaxResults(3)//设置每页记录数pageSize
.list();
for(Book book:list){
System.out.println(book);
}

打印结果为:

Book [id=1, name=鹿鼎记, price=12.35, author=金庸, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@1242f625]
Book [id=2, name=斗破苍穹, price=22.35, author=土豆, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@7f1654f]
Book [id=3, name=吞噬星空, price=27.35, author=番茄, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@7f1654f]

如果将setFilrstResult(),的参数改为3:则会显示:

Book [id=4, name=亮剑, price=42.35, author=都梁, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@1cb6a410]
Book [id=5, name=邪气凛然, price=12.35, author=耳根, pubDate=2016-03-06 09:25:41.0, category=com.wang.pojo.Category@1d0b2840]

需求6:查询图书总数(统计查询):

    //查询图书总数
//结果唯一
//返回一个数据,可能是int,long,double都有可能
    //如果是查询价格最高的图书 hql语句为:"select max(b.price) from Book b";
Number i= (Number)session.createQuery("select count(b.name) from Book b").uniqueResult();
System.out.println("共有图书"+i.intValue()+"本");

需求7:查询每种分类下的图书总数(Group by的使用):

    //查询每种分类下的图书
List<Object[]> list= (List)session.createQuery("select b.category.name,count(b.id) from Book b group by b.category.name").list();
for(Object[] o:list){
System.out.println(o[]+"---"+o[]);
}

需求8:查询"玄幻类"的所有图书信息:

    //查询玄幻类下的图书信息
List<Book> list= (List)session.createQuery("from Book b where b.category.name=:name")
.setParameter("name", "玄幻类")
.list();
for(Book b:list){
System.out.println(b);
}

需求9:查询每个每本图书对应的分类(使用左外连接,为了是结果更有代表性,在category表中添加一条数据"5,情感类"):

        List<Object[]> list= (List)session.createQuery("select c.name,b.name from Category c left outer join c.books b")
.list();
for(Object[] o:list){
System.out.println(o[0]+"----"+o[1]);
}

打印结果为:

武侠类----鹿鼎记
玄幻类----斗破苍穹
玄幻类----吞噬星空
历史类----亮剑
都市类----邪气凛然
情感类----null

Hibernate之HQL查询的一些例子的更多相关文章

  1. hibernate的hql查询

    1.概念介绍 1.Query是Hibernate的查询接口,用于从数据存储源查询对象及控制执行查询的过程,Query包装了一个HQL查询语句. 2.HQL是Hibernate Query Langua ...

  2. Hibernate五 HQL查询

    HQL查询一 介绍1.HQL:Hibernate Query Language,是一种完全面向对象的查询语言.使用Hibernate有多重查询方式可供选择:hibernate的HQL查询,也可以使用条 ...

  3. Hibernate之HQL查询

    一.Hibernate 提供了以下几种检索对象的方式: 导航对象图检索方式: 根据已经加载的对象导航到其他对象 OID 检索方式: 按照对象的 OID 来检索对象 HQL 检索方式:使用面向对象的 H ...

  4. Hibernate 的hql查询简介【申明:来源于网络】

    Hibernate 的hql查询简介[申明:来源于网络] Hibernate 的hql查询简介:http://blog.csdn.net/leaf_130/article/details/539329 ...

  5. hibernate的hql查询语句总结

    这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...

  6. Hibernate(九)HQL查询

    一.Hibernate提供的查询方式 OID查询方式:主键查询.通过get()或者load()方法加载指定OID的对象查询结果为一个 HQL查询方式:通过Query接口使用HQL语言进行查询 QBC查 ...

  7. Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询

    在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object[]数据取出数据,然后自己组bean 解决方 ...

  8. Hibernate 、Hql查询和Criteria查询

    HQL查询: public Object query(String name){ Session s=null; try{ s=HibernateSessionFactory.getSession() ...

  9. Hibernate 中Hql 查询中间表的用法

    案例简述: 项目中存在User 用户表 和 Role 角色表 它们之间是多对多的关系 在User类定义中 使用hibernate注解 //角色列表 @ManyToMany(targetEntity = ...

随机推荐

  1. Smart3D系列教程3之 《论照片三维重建中Smart3D几个工作模块的功能意义》

    [摘要] 近年来,倾斜摄影测量技术是国际测绘遥感领域近年发展起来的一项高新技术,利用照片进行三维重建成为一项关键性的技术.Smart3D软件,是照片三维重建主流软件之一,本文将就Smart3D建模软件 ...

  2. C++ 小知识积累

    (1)setw和setfill函数 #include<iomanip> 代码: #include<iostream> #include<iomanip> using ...

  3. Django发送邮件

    1. 配置相关参数 如果用的是 阿里云的企业邮箱,则类似于下面: 在 settings.py 的最后面加上这些 EMAIL_BACKEND='django.core.mail.backends.smt ...

  4. Python join()函数

    今天写python 100例时,有个题目是大致是这样的:已知输入形式是1+3+2+1,要求输出形式为1+1+2+3 一开始思路是将输入的字符串用split()函数划分成数组,在对数组进行排序,再用fo ...

  5. 记sql server 2008R2 两台服务器 使用非默认端口的发布订阅

    最近研究数据库的复制.因为要在两台服务器上,当使用数据库的默认1433端口时,订阅发布没有任何问题,考虑到数据库的安全性问题,需要改用其他端口.这里以10010为例. 有A.B两台服务器:A作为发布服 ...

  6. 使用EF取数据库返回的数据

    目录 一.取oracle自定义函数返回的自定义类型. 一.取oracle自定义函数返回的自定义类型. 1.首先创建一个函数返回自定义类型集合 --1.建立自定义类型 CREATE OR REPLACE ...

  7. 每周一书-《鸟哥的Linux私房菜》获奖公布

    <鸟哥的Linux私房菜>一书的赠书活动时间为2016年10月19日到10月31日, 也就是今天结束. 首先要感谢QQ号为:1084830483(路在远方),来自哈尔滨工程大学的同学赠送给 ...

  8. ASP.Net请求处理机制初步探索之旅 - Part 3 管道

    开篇:上一篇我们了解了一个ASP.Net页面请求的核心处理入口,它经历了三个重要的入口,分别是:ISAPIRuntime.ProcessRequest().HttpRuntime.ProcessReq ...

  9. .Net开发笔记(十五) 基于“泵”的TCP通讯(接上篇)

    上一篇博客中说了基于“泵”的UDP通讯,附上了一个Demo,模拟飞鸽传书的功能,功能不太完善,主要是为了说明“泵”在编程中的应用.本篇文章我再附上一个关于TCP通讯的两个Demo,也都采用了“泵”模式 ...

  10. CefSharp初识--把网页移到桌面

    在开发中我们可曾有过这样的需求,将某个网页嵌入到.Net应用中来,但Winform自带的web browser不怎么理想.CefSharp可以让我们在.Net应用中嵌入一个Chromium.它提供了W ...