复习 - 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达内五天复习笔记》是一份详细记录了Hibernate框架学习的资料,旨在帮助读者深入理解并掌握Hibernate这一强大的Java持久化框架。以下是笔记中的主要知识点: 1. **ORM原理**: - **对象持久化**:将...
- **Hibernate** 作为 ORM 工具,极大地简化了数据库操作,提高了开发效率。 - **Struts** 通过 MVC 架构,清晰地区分了数据处理、显示和控制的职责,有助于构建结构清晰、易于维护的 Web 应用。 这三个框架的结合...
以上仅是部分Java面试中常见的问题及知识点,实际面试中可能还会涉及其他领域,如Hadoop的HDFS读写流程、分布式系统设计、大数据处理框架等。对于大数据面试,全面掌握Java基础,理解并发编程、数据结构和算法,以及...
本复习旨在深入理解Hibernate的核心概念、配置及常用API,帮助开发者提高开发效率。 一、Hibernate概述 Hibernate是Java领域中流行的ORM(Object-Relational Mapping)框架,它通过映射关系数据库与Java类,实现了...
Java面试复习总结主要涵盖了几大框架的技术点,包括Tapestry、Struts、SpringMVC、Spring、Hibernate和MyBatis,以及拦截器和过滤器的相关概念。 1. **Tapestry**: - Tapestry是一个MVC+模板技术的前端框架,其...
在Java Web开发中,Spring、SpringMVC和Hibernate是三个非常重要的框架,它们分别负责依赖注入、Web请求处理和对象关系映射。将这三个框架整合在一起,可以构建出高效、灵活且易于维护的Web应用程序。下面将详细解析...
在IT领域,尤其是在Java开发中,Hibernate是一个非常重要的对象关系映射(ORM)框架,它极大地简化了数据库操作。本文将深入探讨 Hibernate 中的多对多关联映射,这是一个复杂但常见的数据模型关系,适用于那些两个...
#### 三、Hibernate数据持久化技术 Hibernate作为一款优秀的ORM(Object-Relational Mapping)框架,提供了丰富的API用于处理Java应用与关系型数据库之间的交互。配置数据库连接是使用Hibernate的首要步骤,通常需要...
通过个人总结和复习,我们可以深入理解SSH的内在原理,例如Struts的拦截器机制、Spring的IoC和AOP原理以及Hibernate的缓存策略。在实际项目中,我们需要灵活运用这些知识,结合最佳实践,以解决各种业务需求。同时,...
- Spring:一个轻量级的IoC容器和AOP框架,广泛应用于企业级应用开发中。 #### 三、HTTP请求与响应 - **HTTP协议简介**(K17-K26) - HTTP(HyperText Transfer Protocol)是一种用于Internet上传输请求和响应的...
Struts2、Spring和Hibernate是J2EE环境下常用的三大框架,它们各自解决了Web应用开发中的不同问题。 首先,让我们来看看Struts2。Struts2是一个基于MVC(Model-View-Controller)设计模式的Java Web框架,它旨在...
二是提供了数据访问抽象层,使得开发者可以利用Spring的JDBC模板或者集成Hibernate来处理数据库操作。Spring的声明式事务管理也是其一大亮点,它允许开发者在不编写任何事务代码的情况下,对事务进行管理。 ...
在【基础复习 上课示例】中,学习者会接触到Hibernate的基础概念和核心功能,例如: 1. **对象关系映射(ORM)**:Hibernate是ORM的一种实现,它允许程序员用面向对象的方式处理数据库,通过XML或注解配置将Java类...
在IT行业中,Spring和Hibernate是两个非常重要的框架,它们分别主导了Java应用的两大领域:Spring作为全面的轻量级应用框架,负责依赖注入、事务管理、AOP(面向切面编程)等;而Hibernate则是一个强大的ORM(对象...
根据给定文件中的标题、描述、标签以及部分内容,可以总结并生成以下与J2EE SSH框架相关的知识点: ### J2EE SSH框架理论复习 #### 一、基础知识回顾 1. **J2EE(Java 2 Platform, Enterprise Edition)**: - 是...
- **简化数据库操作**:Hibernate提供了一种更简洁的方式处理数据库交互; - **优化项目结构**:利用Struts1进行视图展示,Spring进行控制层和业务层的管理,层次更加清晰。 #### 二、整合步骤 ##### 1. 创建...
通过对象关系映射(ORM),Hibernate可以将Java对象直接映射到数据库表,使得开发者可以使用面向对象的方式来操作数据,无需编写大量的SQL语句。它还提供了缓存机制和事务管理功能,提高了应用程序的性能和可维护性...
Spring是Java开发中最广泛应用的轻量级框架,它提供了全面的软件基础设施支持,包括依赖注入、面向切面编程(AOP)、数据访问、事务管理、web应用以及大量的可重用组件。 【描述】中的信息表明,这份复习题旨在帮助...