`

Hibernate HQL示例二:list与iterate的区别

阅读更多

示例演示查询list与iterate的区别

1、实体对象的查询,查询的是实体对象的数据【重要】
  * n+1问题,在默认配置的情况下,使用query.iterate()操作,有可能有n+1问题,所谓
  n+1,指在查询对象数据的时候,发出了n+1条查询语句。
  1:首先发出了一条查询语句,查询对象的id列表
  n:在迭代访问每个对象的时候,如果缓存中没有对象数据,Hibernate会在此发出一条查询语句,
     查询相应的对象 
  
  *List操作与Iterate操作的区别
   list,每次都会发出一条查询语句,查询所有的对象
   iterate,首先发出一条查询语句,查询对象的id列表,然后根据缓存情况,决定
    是否发出更多的查询语句,来查询对象数据

 查看下面的代码:

package com.bjsxt.hibernate;

import java.util.Iterator;
import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;

import junit.framework.TestCase;

/**
 * 对象查询中的list操作和iterator操作的差异
 * @author Administrator
 *
 */
public class SimpleObjectQueryTest2 extends TestCase {
	
	public void testQueryWithListMethod() {
			Session session = null;
			try {
				session = HibernateUtils.getSession();
				
				/**
				 * 将发出一条查询语句,获取Student的集合数据
				 * select student0_.id as id1_, student0_.name as name1_, 
				 * student0_.createTime as createTime1_, student0_.classid as classid1_ 
				 * from t_student student0_
				 */
				List students = session.createQuery("from Student").list();
				for (Iterator iter = students.iterator();iter.hasNext();) {
					Student student = (Student)iter.next();
					System.out.println(student.getName());
				}
			}catch(Exception e) {
				e.printStackTrace();
			}finally {
				HibernateUtils.closeSession(session);
			}	
		}		
	
	public void testQueryWithIterateMethod() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			
			//先发出查询id的列表语句
			//select student0_.id as col_0_0_ from t_student student0_
			//再依次发出查询对象的sql(根据id)
			//select student0_.id as id1_0_, student0_.name as name1_0_, 
			//student0_.createTime as createTime1_0_, student0_.classid as classid1_0_ 
			//from t_student student0_ where student0_.id=?
			Query query = session.createQuery("from Student");
			Iterator students = query.iterate();
			while (students.hasNext()) {
				Student student = (Student)students.next();
				System.out.println(student.getName());
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}	
	}	
	
	public void testQueryWithListAndIterate() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			Query query = session.createQuery("from Student");
			List students = query.list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				Student student = (Student)iter.next();
				System.out.println(student.getName());
			}
			
			//如果使用iterate进行查询
			//因为list操作已经将对象加载到了session的一级缓存,所以
			//再使用iterate操作的时候,它先会发出查询id列表的查询语句
			//再根据id到缓存中获取相关的数据
			//只有再缓存中找不到相关数据的情况下,才会再次发出sql进行查询
			Iterator studentsIter = query.iterate();
			while (studentsIter.hasNext()) {
				Student student = (Student)studentsIter.next();
				System.out.println(student.getName());
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}	
		
	}
	
	public void testQueryWithListAndList() {
		Session session = null;
		try {
			session = HibernateUtils.getSession();
			Query query = session.createQuery("from Student");
			List students = query.list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				Student student = (Student)iter.next();
				System.out.println(student.getName());
			}
			
			//再次发出发出sql
			//在默认情况下,list每次都会向数据库发出查询对象数据的sql,
			//除非配置了查询缓存,所以下面的list()操作,虽然在session已经有了
			//对象缓存数据,但list()并不理会这个中缓存,而再次发出查询语句进行查询
			students = query.list();
			for (Iterator iter = students.iterator();iter.hasNext();) {
				Student student = (Student)iter.next();
				System.out.println(student.getName());
			}
		}catch(Exception e) {
			e.printStackTrace();
		}finally {
			HibernateUtils.closeSession(session);
		}	
	}
	
	
}

 

 

详细查看注释部分代码.

以后对查询的性能优化..

分享到:
评论

相关推荐

    Hibernate教程24_Hibernate的补充_list与iterator

    【标题】"Hibernate教程24_Hibernate的补充_list与iterator" 在Java开发中,Hibernate作为一款流行的ORM(对象关系映射)框架,极大地简化了数据库操作。本教程将重点讲解在使用Hibernate时,如何处理查询结果集合...

    HQL实用技术

    - **Query.list()** 和 **Query.iterate()** 的主要区别在于返回类型和查询策略: - **Query.list()** 直接查询数据库,并将结果存储在内存中,适合数据量较小的情况。 - **Query.iterate()** 则会先获取ID列表,...

    HQL连接查询和注解使用总结

    - **隐式内连接与迫切内连接区别**: - 内连接返回的是`Object[]`数组对象,里面存储的是结果集中返回的多个对象。 - 迫切内连接返回的是`from`后面的对象,将`fetch`关键字后面的对象读取并填充到`from`后面的...

    hibernate对二级缓存的理解

    《深入理解Hibernate二级缓存机制》 在Java的持久化框架Hibernate中,缓存机制扮演着重要的角色,尤其是在处理大量数据时,它可以显著提高应用程序的性能。然而,许多人对Hibernate的二级缓存可能存在误解,因此...

    hibernate语句大全

    本篇文章主要介绍初学者在学习Hibernate时会遇到的基础语句,通过简单的示例帮助读者快速上手并理解Hibernate的基本操作。 #### 二、基础语句详解 ##### 1. 迭代器方式(Iterator) - **应用场景**:当需要遍历...

    HIBERNATE_QUERY

    QBE允许通过一个实体示例来构建查询条件,从而获取与示例相匹配的对象集合。例如: ```java Cat exampleCat = new Cat(); exampleCat.setName("Tom"); List<Cat> cats = session.createCriteria(Cat.class) .add...

    hibernate 简单CRUD操作

    - `list()`、`uniqueResult()`、`iterate()`等方法处理查询结果。 3. **更新(Update)** - 修改对象的属性,然后调用`Session`的`update()`方法将对象的状态同步到数据库。 - 或者,先`load()`或`get()`对象,...

    hibernate查询

    2. **Hibernate Query Language (HQL)** - **标准查询**: - `String sql = "from Customer as customer where customer.age = 20";` - `Query q = session.createQuery(sql);` - **选择特定字段**: - `String...

    hibernateTemplate的常用方法

    6. **load(Class entityClass, Serializable id)**:与`get`类似,但当找不到对应的记录时,不会抛出异常而是返回`null`。 - **示例**: ```java Long id = 1L; Teacher teacher = (Teacher) hibernateTemplate....

    hibernate批量删除.txt

    本文将详细介绍如何通过Hibernate进行批量删除,并探讨其背后的工作原理与优化技巧。 #### 二、批量删除的基本方法 1. **基本思路**:批量删除可以通过执行一次或多条SQL语句来完成。通常情况下,为了提高效率,...

    SSH框架和Oracle的简单应用

    #### 二、Hibernate基础 ##### 1. Hibernate入门 Hibernate是一种ORM框架,它允许开发者将Java对象直接映射到关系型数据库的表中,从而简化了数据库操作的过程。持久化是指将瞬时数据转化为持久状态的过程,即把内存...

Global site tag (gtag.js) - Google Analytics