近期,一直在学习Hibernate,翻开以前的学习资料,发现自己以前总结的Hibernate知识点好久没有看过了,学习知识要时常温故而知新,这样才能不会忘记一些零碎的知识,下面,我关于Hibernate的查询给总结了一下,希望对后来学习Hibernate的同学有所帮助,持久化操作无非就是增删改查,重点就在于查。
注意:关键字不区分 类和属性区分
1 简单属性查询
*单一属性查询,默认返回结果列表,其元素属性和实体对象的属性类型一致
*多个属性查询,返回集合,集合元素是对象数组,数组的长度决定查询的属性个数
数组中元素的类型决定于查询的属性在实体中的类型
*如果觉得数组不过面向对象,可以采用HQL动态实例化Student对象
select new Student(id,name) from Student
单个属性
List l = session.createQuery("select name from Student").list();
//返回结果集属性列表,其元素与属性的类型一致
多个属性
List l = session.createQuery("select id,name from Student").list();
//查询多个属性,其集合元素是对象数组
//元素类型和实体类型一致
//数组的长度取决与你查询属性的个数
List l = session.createQuery("select new Student(id,name) from Student").list(); 返回是对象
使用别名
List l = session.createQuery("select s.id,s.name from Student s").list();
使用as
List l = session.createQuery("select s.id,s.name from Student as s").list();
2 查询实体对象(重要)
*什么是n+1 在默认情况下使用query.iterate()查询的时候,有可能有n+1问题,所谓
n+1是在查询对象的时候发出了n+1条语句
1 首先发出一条查询实体对象的id的列表
n 再根据id去缓存中查询,如果缓存中有与之匹配的数据,那么就取得缓存数据
否则依次个根据id发出sql语句
//可以忽略select 返回实体对象
List students = session.createQuery("from Student").list();
//可以忽略select 表可以加别名 返回实体对象
List students = session.createQuery("from Student s").list();
//可以忽略select 表可以加别名 可以用as返回实体对象
List students = session.createQuery("from Student as s").list();
//使用select查询 必须定义别名
List students = session.createQuery("select s from Student as s").list();
//不能使用select * from``` 这样的hql 错误
List students = session.createQuery("select * from Student as s").list();
list()个iterate()的区别
list:在默认情况下list每次会发出sql语句
iterate:首先发出一条查询实体对象的id的列表
再根据id去缓存中查询,如果缓存中有与之匹配的数据,那么就取得缓存数据
否则依次个根据id发出sql语句
3 条件查询
*可以采用拼字符串的方式传递参数
*还可以采用?来传递参数(索引从0开始)
*可以采用冒号 :参数名 来传递
*如果对应的参数多可以采用setParameterList()方法
*在hql可以使用数据库的函数 如:substring,date_format
//条件查询 拼字符串
List students = session.createQuery("select s.id,s.name from Student s where s.name like '%1%'").list();
//条件查询,使用?的方式
//参数索引从零开始
//传递参数无需使用单引号
//注意方法链编程
List students = session.createQuery("select s.id,s.name from Student s where s.name like ?").setParameter(0, "%1%").list();
/*
* 条件查询,使用:参数名 的方式传递参数
*/
List students = session.createQuery("select s.id,s.name from Student s where s.name like :myname").setParameter("myname", "%1%").list();
/*
* 条件查询,使用:参数名 的方式传递参数
*/
List students = session.createQuery("select s.id,s.name from Student s where s.name like :myname and s.id=:myid")
.setParameter("myname", "%1%")
.setParameter("myid", 11)
.list();
/*
* 条件查询,使用:参数名 的方式传递参数
*/
List students = session.createQuery("select s.id,s.name from Student s where s.id in(:myids)")
.setParameterList("myids", new Object[]{1,4,5,8})
.list();
//使用库函数
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
List students = session.createQuery("select s.id,s.name from Student s where s.createTime between ? and ? order by s.id")
.setParameter(0, sdf.parse("2008-02-01"))
.setParameter(1, sdf.parse("2008-02-29"))
.list();
//2008-02创建的学生
/*List students = session.createQuery("select s.id,s.name from Student s where substring(s.createTime,1,7)=? order by s.id")
.setParameter(0, "2008-02")
.list();*/
List students = session.createQuery("select s.id,s.name from Student s where date_format(s.createTime,'%Y-%m')=? order by s.id")
.setParameter(0, "2008-02")
.list();
4 外置命名查询
*在映射文件中采用<query>定义hql
*在程序中使用session.getNameQuery()方法得带这个查询
Xml
<query name="serchStudents">
<![CDATA[
select s from Student s where s.id<?
]]>
</query>
程序中
List students = session.getNamedQuery("serchStudents")
.setParameter(0, 10)
.list();
5 查询过滤器
*定义过滤器参数
*在类的映射文件中使用过滤器参数
*在程序要使用过滤器
session.enableFilter("filtertest")
.setParameter("myid", 10);
Class标签内
<filter name="filtertest" condition="id <:myid"></filter>
Class标签外
<filter-def name="filtertest">
<filter-param name="myid" type="integer"/>
</filter-def>
6 hibernate也支持使用原生aql查询 返回对象数组
List students = session.createSQLQuery("select * from t_student").list();
for(Iterator iter = students.iterator();iter.hasNext();){
Object[] obj = (Object[])iter.next();
System.out.println(obj[0]+","+obj[1]);
}
7 分页查询(重要)
需要2个参数,起始记录数
.setFirstResult(0)
.setMaxResults(2)
List students = session.createQuery("from Student")
.setFirstResult(0)
.setMaxResults(2)
.list();
8 对象导航查询,在hql使用.进行导航查询
List students = session.createQuery("select s from Student s where s.classes<5").list();
9 连接查询(重要)
*内连接
*外连接(左连接/右连接
内连接
List students = session.createQuery("select c.name,s.name from Student s join s.classes c ").list();
for(Iterator iter = students.iterator(); iter.hasNext();){
Object[] obj = (Object[])iter.next();
System.out.println(obj[0]+","+obj[1]);
}
左连接
//显示无学生的班级
List students = session.createQuery("select c.name,s.name from Classes c left join c.students s ").list();
for(Iterator iter = students.iterator(); iter.hasNext();){
Object[] obj = (Object[])iter.next();
System.out.println(obj[0]+","+obj[1]);
}
右连接
//显示无班级的学生
List students = session.createQuery("select c.name,s.name from Classes c right join c.students s ").list();
for(Iterator iter = students.iterator(); iter.hasNext();){
Object[] obj = (Object[])iter.next();
System.out.println(obj[0]+","+obj[1]);
}
10 统计查询
统计总数
/*List student = session.createQuery("select count(*) from Student").list();
int count = (Integer)student.get(0);*/
Long count = (Long)session.createQuery("select count(*) from Student").uniqueResult();
查询班级与其的学生总数
List students = session.createQuery("select c.name ,count(s) from Student s join s.classes c " +
"group by c.name order by c.id").list();
for(Iterator iter = students.iterator();iter.hasNext();){
Object[] obj = (Object[])iter.next();
System.out.println(obj[0]+","+obj[1]);
}
11 DML风格的操作(尽量少用)
不会同步缓存
批量更新
session.createQuery("update Student s set s.name = ? where s.id in(:myids) ")
.setParameter(0, "张三")
.setParameterList("myids", new Object[]{1,2,3,4})
.executeUpdate();
分享到:
相关推荐
Hibernate hql查询语法总结 Hibernate hql查询语法总结
hibernate多表联合查询实例,很经典的查询语句和总结.
hibernate的几种查询方式总结,hql,Criteria等
hibernate中,对其中的查询方式进行总结,包括hql查询,条件查询,sql查询等
Hibernate HQL查询语句总结.docx 网络下载的
第一:关于cretiria的查询 第二:HQL查询 第三,本地SQL查询
Hibernate目前总共分为三大类查询:cretiria,hql,本地sql 详细介绍着三种方式的区别和用法
4、使数据格式,便于管理和查询 对象持久化的途径: 1、对象序列化:不适合大量数据操作 2、关系型数据库 企业计算的需求: 1、海量数据的存储 2、大规模的查询,报表 3、稳固的数据完整性...
该源代码配了了解释,针对hibernate中多表查询的多种形式进行了总结,很有价值,有Object[]形式的查询,也有对象方式的查询 也有集合list形式的查询,
Hibernate_二级缓存总结 开发技术 - Java.zip
根据自己学习总结的一些hibernate资料,包括全面介绍关系配置和各种查询,都有详细的说明。还有自己写的一些小dome。希望对初学者有帮助!
hibernate查询,结合hibernate的模糊查询,等其他总结。
Hibernate HQL 查询 Query 资料 3个word总结的资料。
SHH两年工作经验:hibernate缓存总结和优化
hibernate 查询缓存 (hibernate 默认是关闭的 ) 查询缓存是针对普通属性结果集的缓存 对实体对象的结果集只缓存 id 查询缓存的生命周期,当前关联的表发生修改,那么查询缓存生命周期结束 查询缓存的配置和使用...
14. HQL: Hibernate查询语言 14.1. 大小写敏感性问题 14.2. from子句 14.3. 关联(Association)与连接(Join) 14.4. join 语法的形式 14.5. select子句 14.6. 聚集函数 14.7. 多态查询 14.8. where子句 14.9....
1. get() and load() Java代码 session.get(Clazz, id); session.load(Clazz, id); session.get(Clazz, id); session.load(Clazz, id); 说明: load()与get()的区别 请注意如果没有匹配的数据库记录,load()方法可能...
Hibernate中Criteria的完整用法 Criteria 是一个完全面向对象,可扩展的条件查询API,通过它完全不需要考虑数据库底层如何实现、SQL语句如何...
Hibernate的检索方式:(查询/加载) 1. 通过OID加载 session.get(Users.class, 1); * 2. 通过HQL/SQL 检索 hibernate query language (面向对象的查询语言) * a) 不再操纵表,它操纵的是持久化类的对象 b) 面向...
方便 Hibernate 注解的查询使用,包含了常用的注解及其属性值和说明!