`
wuyafeng123
  • 浏览: 24350 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

关于Hibernate的查询总结

阅读更多
    近期,一直在学习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 &lt;: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知识点总结

    ### Hibernate知识点总结 #### 一、Hibernate概述 Hibernate是一个开源的ORM(Object Relational Mapping,对象关系映射)框架,用于Java应用与关系型数据库之间的交互。它通过使用描述对象和数据库之间映射的元...

    hibernate学习总结文档

    2. **读取(Read)**:`get()` 或 `load()` 方法用于根据主键获取对象,`query()` 或 HQL(Hibernate 查询语言)用于执行更复杂的查询。 3. **更新(Update)**:修改对象后,调用 `update()` 或 `merge()` 方法同步...

    Hibernate 简单 PPT 总结

    【Hibernate 简单 PPT 总结】 Hibernate 是一个流行的开源对象关系映射(ORM)框架,它简化了Java应用程序对数据库的操作。通过提供一套API和元数据,Hibernate允许开发者将业务对象直接映射到数据库表,从而避免了...

    Hibernate4总结文档

    《Hibernate4总结文档》 Hibernate4作为一款强大的Java对象关系映射框架,简化了数据库操作,使得开发者可以更专注于业务逻辑而不是数据库层面的细节。本文将深入探讨Hibernate4的配置和使用,帮助开发者更好地理解...

    hibernate文档总结,技术汇总,PDF版的,hibernate简明参考文档

    以下是关于Hibernate的一些关键知识点: 1. **JDBC对比Hibernate**: 传统的JDBC操作涉及手动建立和管理数据库连接,而Hibernate通过提供更高层次的抽象,自动处理这些细节,使得开发人员可以更专注于业务逻辑。 2....

    通用的hibernate查询

    本篇文章将深入探讨通用的Hibernate查询方法,特别是关于分页查询的应用。 在Hibernate中,查询数据主要通过Criteria、HQL(Hibernate Query Language)和Query API三种方式。首先,让我们来看看Criteria查询。...

    Hibernate连表查询 Hibernate连表查询

    根据提供的文件信息,我们可以深入探讨Hibernate中的连表查询方法及其应用。下面将详细介绍与标题、描述及部分代码相关的几个核心知识点: ### Hibernate 连表查询基础 Hibernate 是一个开源的对象关系映射(ORM)...

    struts+hibernate查询所有记录

    ### Struts+Hibernate查询所有记录 #### 一、概述 在Java Web开发中,Struts与Hibernate是非常流行的框架组合,用于构建复杂的...以上就是关于Struts+Hibernate查询所有记录的相关知识点介绍。希望对大家有所帮助!

    Hibernate_query查询数据表中的一个字段.

    总结,Hibernate提供多种方式查询数据表中的字段,包括HQL、Criteria API和DetachedCriteria,选择合适的方法取决于具体需求。正确理解和使用Hibernate,能够大大提高Java开发中的数据库操作效率。

    hibernate多表联合查询

    ### Hibernate多表联合查询详解 #### 一、引言 在实际项目开发中,我们经常需要处理复杂的数据库查询,特别是涉及到多个表之间的关联查询。Hibernate作为一款流行的Java持久层框架,提供了一种非常便捷的方式来处理...

    Hibernate hql查询语法总结

    本文将对Hibernate HQL查询语法进行总结,涵盖基础查询、属性查询、实例化查询以及查询链接等多个方面。 1. 基础查询: 基础查询是最简单的HQL语句,用于获取所有`Student`对象。例如: ```java from Student ``` ...

    Hibernate学习笔记与总结

    **Hibernate学习笔记与总结** Hibernate 是一款开源的对象关系映射(ORM)框架,它为Java开发者提供了一种在关系数据库上操作对象数据的便捷方式。本文将深入探讨Hibernate的核心概念、配置、实体类、映射文件、...

    Hibernate三大类查询总结

    本文将对Hibernate的三大类查询进行详细总结,包括Cretiria查询、HQL查询以及本地SQL查询。 首先,我们来看Cretiria查询,这是Hibernate提供的一种基于对象的查询方式,具有高度的灵活性和可扩展性。`Criteria`接口...

    Hibernate重点总结

    在本文中,我们将深入探讨Hibernate的关键概念、配置、实体管理、查询语言以及缓存机制。 1. **基本概念** - **对象关系映射(ORM)**: ORM是将数据库表映射为Java类,将SQL语句转换为对象操作的一种技术,简化了...

    hibernate实现动态SQL查询

    本篇文章主要探讨如何利用Hibernate实现动态SQL查询,结合XML配置和FREEMARKER模板引擎来生成执行的SQL语句。 一、Hibernate简介 Hibernate作为一款强大的持久层框架,它简化了Java应用程序与数据库之间的交互。...

    Hibernate的查询方式

    ### Hibernate的查询方式详解 #### 引言 Hibernate作为Java领域中最流行的ORM(Object-Relational Mapping)框架之一,提供了一系列高效、灵活的查询机制,旨在桥接对象模型与关系数据库之间的鸿沟。本文将深入...

    Hibernate三大类查询总结.doc

    《Hibernate三大类查询总结》 在Java的持久化框架中,Hibernate以其强大的功能和易用性占据了重要地位。在处理数据库查询时,Hibernate提供了三种主要的查询方式:Criteria查询、HQL(Hibernate Query Language)和...

Global site tag (gtag.js) - Google Analytics