`
spring-china
  • 浏览: 50787 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

复习 - Hibernate大数据量处理的简单总结

阅读更多

复习 - Hibernate大数据量处理的简单总结

 

对于Hibernate大数据量的处理,我也有点体会,之前的一个集成项目数据量很大,最初用Java(Hiberante)去处理,性能不尽人意,即使使用纯JDBC去操作,效果仍不佳,其实当时的需求是表之间大数据的转换复制处理,所以使用Java进行处理这个方向就不太对,直接使用PLSQL才是最快捷的方式,这样就不必将数据加载到内存,经过处理再写入数据库。但是对于小数据量的处理,使用Hibernate是个很好的方式,毕竟使用Java进行一些逻辑的操作和封装,比使用plsq更直观,更方便。

 

这里也总结一下Hibernate对于大数据量处理的一些方法,根据数据需不需要加载到内存中可以分成,需要注意的是实际的项目开发中可能没有这么简单的逻辑,需要自己去斟酌研究,选择一个合适的方式啦

 

1.  数据不在内存中 ----------------------- 直接用sql或hql进行处理.

这种情况不需要将数据加载到内存,也就是不需要涉及到持久化环境,那当然最好,直接用sql或者hql去进行处理咯. 

通常是一些直接的对db进行批量操作的动作,不需要对相关的数据进行处理. 

 

2.  要操作的数据位于内存中 

(1) 首先,如果是批量的插入. -------------- 可以定期使用session.flush(), session.clear()进行处理

比如,在插入了1000条之后,就进行手动的flush和clear

如:

 

package com.yxy.test;

import java.util.Date;

import org.hibernate.Session;
import org.hibernate.SessionFactory;

import com.yxy.bean.Student;

public class HibernateBatchTest {
	
	public static void main(String[] args){
		
		SessionFactory sessionFactory = HibernateUtils.getSessionFactory();
		Session session = sessionFactory.openSession();
		session.getTransaction().begin();
		
		for(int i=0; i<100000; i++){
			Student s = new Student();
			s.setName("student"+i);
			s.setRegisterDate(new Date(System.currentTimeMillis()));
			s.setSex("Female");
			if(i%1000 == 0){
				session.flush();
				session.clear();
			}
		}
		
		session.getTransaction().commit();
		session.close();
	}
}

 

 

(2) 如果是批量的更新,可以使用类似于游标的功能,在游标滚动到一定数量的记录时手动的进行flush和clear

需要用到的是ScrollableResults这个类,例子如下:

 

ScrollableResults cursor = session.createQuery("from Student").scroll();
		
int counter = 0;
while(cursor.next()){
	Student s = (Student)cursor.get(0);
	s.setName("student cursor");
	if(counter++ % 1000 == 0){
		session.flush();
		session.clear();
	}
}

 

 

最后还有一个StatelessSession的类,它和Session的区别就是它不会考虑持久化环境的,即忽略一级缓存,忽略脏数据检查等等. 这样可以节省一定开销,但是我没有在实际中用过这个方法。

 

分享到:
评论

相关推荐

    hibernate达内五天复习笔记.pdf

    《Hibernate达内五天复习笔记》是一份详细记录了Hibernate框架学习的资料,旨在帮助读者深入理解并掌握Hibernate这一强大的Java持久化框架。以下是笔记中的主要知识点: 1. **ORM原理**: - **对象持久化**:将...

    燕山大学 spring hibernate struts 三大框架 期末复习资料

    - **Hibernate** 作为 ORM 工具,极大地简化了数据库操作,提高了开发效率。 - **Struts** 通过 MVC 架构,清晰地区分了数据处理、显示和控制的职责,有助于构建结构清晰、易于维护的 Web 应用。 这三个框架的结合...

    大数据面试复习----常问问题分析.docx

    以上仅是部分Java面试中常见的问题及知识点,实际面试中可能还会涉及其他领域,如Hadoop的HDFS读写流程、分布式系统设计、大数据处理框架等。对于大数据面试,全面掌握Java基础,理解并发编程、数据结构和算法,以及...

    复习hibernate

    本复习旨在深入理解Hibernate的核心概念、配置及常用API,帮助开发者提高开发效率。 一、Hibernate概述 Hibernate是Java领域中流行的ORM(Object-Relational Mapping)框架,它通过映射关系数据库与Java类,实现了...

    java面试复习总结.doc.docx

    Java面试复习总结主要涵盖了几大框架的技术点,包括Tapestry、Struts、SpringMVC、Spring、Hibernate和MyBatis,以及拦截器和过滤器的相关概念。 1. **Tapestry**: - Tapestry是一个MVC+模板技术的前端框架,其...

    spring+spingmvc+hibernate整合总结

    在Java Web开发中,Spring、SpringMVC和Hibernate是三个非常重要的框架,它们分别负责依赖注入、Web请求处理和对象关系映射。将这三个框架整合在一起,可以构建出高效、灵活且易于维护的Web应用程序。下面将详细解析...

    hibernate知识复习四:多对多关联映射

    在IT领域,尤其是在Java开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作。本文将深入探讨 Hibernate 中的多对多关联映射,这是一个复杂但常见的数据模型关系,适用于那些两个...

    J2EE考试复习试题_struts2_spring_hibernate(答案整合完毕

    #### 三、Hibernate数据持久化技术 Hibernate作为一款优秀的ORM(Object-Relational Mapping)框架,提供了丰富的API用于处理Java应用与关系型数据库之间的交互。配置数据库连接是使用Hibernate的首要步骤,通常需要...

    三大框架个人总结

    通过个人总结和复习,我们可以深入理解SSH的内在原理,例如Struts的拦截器机制、Spring的IoC和AOP原理以及Hibernate的缓存策略。在实际项目中,我们需要灵活运用这些知识,结合最佳实践,以解决各种业务需求。同时,...

    JavaEE开发基础复习所有内容

    - Spring:一个轻量级的IoC容器和AOP框架,广泛应用于企业级应用开发中。 #### 三、HTTP请求与响应 - **HTTP协议简介**(K17-K26) - HTTP(HyperText Transfer Protocol)是一种用于Internet上传输请求和响应的...

    java web复习试题

    Struts2、Spring和Hibernate是J2EE环境下常用的三大框架,它们各自解决了Web应用开发中的不同问题。 首先,让我们来看看Struts2。Struts2是一个基于MVC(Model-View-Controller)设计模式的Java Web框架,它旨在...

    Spring+Hibernate小程序

    二是提供了数据访问抽象层,使得开发者可以利用Spring的JDBC模板或者集成Hibernate来处理数据库操作。Spring的声明式事务管理也是其一大亮点,它允许开发者在不编写任何事务代码的情况下,对事务进行管理。 ...

    北大青鸟ACCP6.0 第三学期 Y2 JAVA方向 hibernate框架

    在【基础复习 上课示例】中,学习者会接触到Hibernate的基础概念和核心功能,例如: 1. **对象关系映射(ORM)**:Hibernate是ORM的一种实现,它允许程序员用面向对象的方式处理数据库,通过XML或注解配置将Java类...

    hibernate-tutorial:一个在Spring和Hibernate上进行复习的教程项目

    在IT行业中,Spring和Hibernate是两个非常重要的框架,它们分别主导了Java应用的两大领域:Spring作为全面的轻量级应用框架,负责依赖注入、事务管理、AOP(面向切面编程)等;而Hibernate则是一个强大的ORM(对象...

    J2EE SSH 笔试复习

    根据给定文件中的标题、描述、标签以及部分内容,可以总结并生成以下与J2EE SSH框架相关的知识点: ### J2EE SSH框架理论复习 #### 一、基础知识回顾 1. **J2EE(Java 2 Platform, Enterprise Edition)**: - 是...

    Struts1SpringHibernate整合总结

    - **简化数据库操作**:Hibernate提供了一种更简洁的方式处理数据库交互; - **优化项目结构**:利用Struts1进行视图展示,Spring进行控制层和业务层的管理,层次更加清晰。 #### 二、整合步骤 ##### 1. 创建...

    java ee 复习笔记

    通过对象关系映射(ORM),Hibernate可以将Java对象直接映射到数据库表,使得开发者可以使用面向对象的方式来操作数据,无需编写大量的SQL语句。它还提供了缓存机制和事务管理功能,提高了应用程序的性能和可维护性...

    SVSE-S3冲刺题-spring复习题

    Spring是Java开发中最广泛应用的轻量级框架,它提供了全面的软件基础设施支持,包括依赖注入、面向切面编程(AOP)、数据访问、事务管理、web应用以及大量的可重用组件。 【描述】中的信息表明,这份复习题旨在帮助...

Global site tag (gtag.js) - Google Analytics