Hibernate--------八大类HQL查询集合
一:属性查询(SimplePropertyQuery)
1,单一属性查询
*返回结果集属性列表,元素类型和实体类中相应的属性一致
2, 多个属性查询,
* 返回集合中的元素是object数组,
* 其中数组元素的类型和对应属性在实体类中的类型一致
代码:
for(Iterator iterator=list.iterator();iterator.hasNext();)
{
Object[] obj=(Object[])iterator.next();
System.out.println("sid:="+obj[0].toString()+" sname:="+obj[1]);
}
3, 通过hql来动态实例化对象
代码:
List list=session.createQuery("select new Student(sid,sname) from Student").list();
for (Iterator iterator=list.iterator();iterator.hasNext();){
Student student=(Student) iterator.next();
System.out.println("sid:="+student.getSid()+" sname:="+student.getSname());
}
4,采用别名查询
代码:
//List list=session.createQuery("select s.sid, s.sname from Student as s").list();
List list=session.createQuery("select s.sid, s.sname from Student s").list();
二:简单对象查询(SimplyObjectQuery)
1,返回对象集合(可以忽略select)
代码:
//List list=session.createQuery("from Student").list();
//List list=session.createQuery("from Student as s").list();
List list=session.createQuery("from Student s").list();
2,采用select查询对象
* 必须要使用别名
代码:
//List list=session.createQuery("select s from Student as s").list();
List list=session.createQuery("select s from Student s").list();
3,查询单一对象的操作
代码:
Object obj=session.createQuery("select s from Student s where s.sid=:mysid")
.setParameter("mysid", 12)
.uniqueResult();
4,分页查询
* setFirstResult(int firstResult)
* Set the first row to retrieve.
* If not set, rows will be retrieved beginnning from row 0.
* firstResult - a row number, numbered from 0
代码:
List list=session.createQuery("select s from Student s")
.setFirstResult(5)
.setMaxResults(5)
.list();
三:简单条件查询(SimpleConditionQuery)
1,可以拼凑字符串
代码:
List stuList=session.createQuery("select s.sid, s.sname from Student as s where s.sname like '%1%'").list();
2,注意:可以采用?占位的方式来传递参数
*参数的索引从0开始
*传递的参数值不能用''号括起来
*注意方法链编程
代码:
/*
*Query query=ession.createQuery("select s.sid, s.sname from Student as s where s.sname like ?");
*query.setParameter(0, "%1%");
*List stuList=query.list();
*/
List stuList=session.createQuery("select s.sid, s.sname from Student as s where s.sname like ?")
.setParameter(0, "%1%")
.list();
3,通过参数名(:参数名)传参的方式进行查询
代码:
/*Object obj=session.createQuery("select s.sid, s.sname from Student as s where s.sname like :myname and s.sid=:myid")
.setParameter("myname", "%1%")
.setParameter("myid", 98)
.uniqueResult();//.list();
Object[] objs=(Object[])obj;
System.out.println("s.sid:="+objs[0].toString()+" s.sname:="+objs[1].toString());
*/
List stuList=session.createQuery("select s.sid, s.sname from Student as s where s.sname like :myname and s.sid=:myid")
.setParameter("myname", "%1%")
.setParameter("myid", 98)
.list();
4,传递多个参数的查询
* 支持in查询,需要setParameterList("myids", new Object[]{12,13,14})的方式进行参数传递
代码:
List stuList=session.createQuery("select s.sid, s.sname from Student as s where s.id in(:myids)")
.setParameterList("myids", new Object[]{12,13,14})
.list();
5, 查询2009年2月入学的学员信息
*支持Sql函数查询
代码:
List stuList=session.createQuery("select s.sid, s.sname ,s.schoolDate from Student as s where year(s.schoolDate)=:myyear and month(s.schoolDate)=:mymonth")
.setParameter("myyear", 2009)
.setParameter("mymonth", 2)
.list();
6,查询2009-02-10到2009-02-15号入学的学员信息
*注意:在进行日期查询时
*setParameter("startDate", formatter.parse("2009-02-10 00:00:00"))
*方法中第二个参数是一个Object对象(Date类型对象)
代码:
SimpleDateFormat formatter=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
List stuList=session.createQuery("select s.sid, s.sname ,s.schoolDate from Student as s where s.schoolDate between :startDate and :endDate")
.setParameter("startDate", formatter.parse("2009-02-10 00:00:00"))
.setParameter("endDate", formatter.parse("2009-02-15 23:59:59"))
.list();
四:原生SQL语句查询(SqlQueryTest_4)
*这里用的是createSQLQuery().list();
代码:
List stuList=session.createSQLQuery("select * from Student").list();
五:外置命名查询(NamedQueryTest_5)
* 1.在映射文件中采用<query>标签来定义HQL语句,不必限定文件!!!注意:映射文件中的HQL语句不可以出错,否则会导致 QuerySyntaxException,特别是要查询的实体类名写错的情况。(Error in named query: selectAllStudents org.hibernate.hql.ast.QuerySyntaxException: Students is not mapped)。
* 2.在程序中通过session.getNamedQuery(hql_name)得到查询语句
代码:
List list=session.getNamedQuery("selectAllStudents")
.setParameter("mysid",12).list();
六:对象导航查询(ObjectNavQueryTest_6)
代码:
List list= session.createQuery("select s.sname from Student as s where s.clsInfo.cname like :myname")
.setParameter("myname", "%1%")
.list();
七:联合查询(JoinQueryTest_7)
1,联合查询* 内连接查询
* 获取已经参加班级报名的所有学生名号和其所在班级名称
代码:
List list=session.createQuery("select s.sname,c.cname from Student as s join s.clsInfo as c").list();
2,联合查询* 左连接查询
* 获取所有班级名称和其学员姓名
* 以班级信息表为主表,进行左外连接查询
代码:
List list=session.createQuery("select c.cname ,s.sname from ClassInfo as c left join c.studentSet as s").list();
3,联合查询 * 右连接查询
* 获取所有学员姓名和其所属班级名称
* 以学员信息表为主表,进行右外连接查询
代码:
List list=session.createQuery("select s.sname, c.cname from ClassInfo as c right join c.studentSet as s").list();
八:(StateQueryTest_8)
1,聚合函数使用
代码:
//List list=session.createQuery("select count(*) from Student").list();
//long count=(Long) list.get(0);
long count=(Long) session.createQuery("select count(*) from Student").uniqueResult();
2,分组查询
代码:
List list=session.createQuery("select c.cname, count(s) from Student as s inner join s.clsInfo as c group by c.cname order by c.cname").list();
Hibernate--------八大类HQL查询集合的更多相关文章
- Hibernate中关于HQL查询返回List<Object>数据的结果集问题
---恢复内容开始--- 开发中遇到的一个小问题,使用Hibernate中的HQL查询时,使用query.list()查询出来的是一个List<Object>结果集 原来代码: publi ...
- 【Hibernate步步为营】--hql查询小介
HQL 是指Hibernate Query Language,它是Hibernate的查询语言,拥有一套自己的查询机制,它的查询语句和SQL非常类似.在使用的时候可以非常快上手.HQL提供了基本上SQ ...
- Hibernate框架之HQL查询与Criteria 查询的区别
Hibernate框架提供了HQL查询和Criteria 查询.下面对这两种查询分别做个例子.也好对这两种查询方法有个大概的了解.就用房屋信息表做例子,查询所有房屋信息. HQL语句查询所有房屋信息: ...
- Hibernate用到HQL查询时的错误
Exception in thread "main" org.hibernate.hql.internal.ast.QuerySyntaxException: student is ...
- hibernate学习(7)——HQL查询
1.HQL查询定义 Hibernate查询分类: 1. get/load 根据OID检索 2. 对象视图检索 c.getOrders 3. Sql语句 createSqlQuery 4. Hql语句 ...
- Hibernate中的HQL查询与缓存机制
HQL:完全面向对象查询 SQL的执行顺序: 1.From 2.Where 过滤基础数据 where与having的区别:1.顺序不同 2.where过滤基础数据 3. 过滤聚合函数 3.Group ...
- Hibernate学习之hql查询语句
* 页面上数据的字段和数据库中字段差不多,这个时候,采用迫切连接 结构比较好,如果页面上的字段很少,要按照需求加载数据,采用带构造函数的select查询 实例讲解:转自:http://www.cn ...
- Java_Web三大框架之Hibernate+jsp+selvect+HQL查询数据
俗话说:"好记性不如烂笔头".本人学习Hibernate也有一个星期了,对Hibernate也有一个初步的了解.下面对Hibernate显示数据做个笔记,使用租房系统的Hibern ...
- Hibernate(十二):HQL查询(一)
概述 Hibernate提供了以下几种检索对象的方式 1)导航对象图检索方式:根据已经加载的对象导航到其他对象: 2)OID检索方式:按照对象的OID来检索对象: 3)HQL检索方式:使用面向对象的H ...
随机推荐
- Android开发学习—— Service 服务
Service运行于后台的一个组件,用来运行适合运行在后台的代码,服务是没有前台界面,可以视为没有界面的activity. 服务可以被手动关闭,不会重启,但是如果被自动关闭,内存充足就会重启. sta ...
- android 自定义控件——(四)圆形进度条
----------------------------------↓↓圆形进度条(源代码下有属性解释)↓↓---------------------------------------------- ...
- 一些Titanium学习的地方
利用titanium兑现外汇兑换计算的ios代码 http://rensanning.iteye.com/blog/1325011 Titanium兑现相关的报表功能 http://www.s ...
- 手机游戏渠道SDK接入工具项目分享(一)缘起
#剧情章节 # 上周刚结束一个外包的项目,开发手机游戏渠道SDK聚合接入工具的,现在有空回顾整理一下这个项目开发过程,因涉嫌商业秘密不会提供项目代码,只谈下开发思路和掉过的坑. 本人多年从事手机互联网 ...
- 苹果 OS X 系统U盘重装-抹盘重装、系统盘制作
鉴于前段时间系统出了点问题,然后直接将盘抹了,来个彻底干净的系统重装.这里敲下过程.(网络恢复太慢了,我整整一个晚上竟然没down下来,恼怒了,直接U盘装) First,系统盘制作: 1.首先需要有: ...
- Linux系统安装MySql步骤及截屏
➠更多技术干货请戳:听云博客 如下是我工作中的记录,介绍的是linux系统下使用官方编译好的二进制文件进行安装MySql的安装过程和安装截屏,这种安装方式速度快,安装步骤简单! 需要的朋友可以按照如下 ...
- installshield使用教程
从Visual Studio 2012开始,微软就把自家原来的安装与部署工具彻底废掉了,转而让大家去安装使用第三方的打包工具“InstallShield Limited Edition for Vis ...
- SQL优化技术分析-4:其他
ORACLE的提示功能是比较强的功能,也是比较复杂的应用,并且提示只是给ORACLE执行的一个建议,有时如果 出于成本方面的考虑ORACLE也可能不会按提示进行.根据实践应用,一般不建议开发人员应用O ...
- vim 中替换
将80替换为10.0.0.19:80 :g/80/s//10.0.0.19:80/g
- 【只需3步】源码手动安装Apache以及配置(亲测可行)
作者小波/QQ463431476欢迎转载! redhat6采用centos yum源. 第一步下载apache依赖的软件包并安装 安装 apr下载地址:http://apr.apache.org/do ...