今天做了一个hibernate关于session的生命周期的测试,用的eclipse的junit工具类。
在昨天入门配置的基础上,创建了一个Sourse folder 名为test,主要放置测试类。
首先解释一下持久化对象:
瞬时对象(Transient Objects):使用new 操作符初始化的对象不是立刻就持久的。它们的状态是瞬时的,也就是说它们没有任何跟数据库表相关联的行为,只要应用不再引用这些对象(不再被任何其它对象所引用),它们的状态将会丢失,并由垃圾回收机制回收。
持久化对象(Persist Objects):持久实例是任何具有数据库标识的实例。它有持久化管理器Session统一管理,持久实例是在事务中进行操作的——它们的状态在事务结束时同数据库进行同步。当事务提交时,通过执行SQL的INSERT、UPDATE和DELETE语句把内存中的状态同步到数据库中。
离线对象(Detached Objects):Session关闭之后,持久化对象就变为离线对象。离线表示这个对象不能再与数据库保持同步,它们不再受Hibernate管理。
生命周期:
配置好后,新建一个HibernateUtils.java类:
package com.mp.hibernate;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
public class HibernateUtils {
public static SessionFactory factory;
static {
try {
Configuration cfg = new Configuration().configure();
factory = cfg.buildSessionFactory();
} catch(Exception e) {
e.printStackTrace();
}
}
public static SessionFactory getSessionFactory() {
return factory;
}
public static Session getSession() {
return factory.openSession();
}
public static void closeSession(Session session) {
if(session != null) {
if(session.isOpen()) {
session.close();
}
}
}
}
这个类就是把对session的基本操作封装起来。
在数据库中新建了hibernate_session数据库,并且修改hibernate.cfg.xml文件中的配置。
在test中建了一个测试类SessionTest.java
首先对session的三个状态进行测试:
package com.mp.hibernate;
import java.util.Date;
import org.hibernate.Session;
import org.hibernate.Transaction;
import junit.framework.TestCase;
public class SessionTest extends TestCase {
public void testHello() {
System.out.println("-----------SessionTest.hello()------------");
//throw new RuntimeException();
}
public void testSave1() {
Session session = null;
Transaction ts = null;
User user = null;
try {
session = HibernateUtils.getSession();
ts = session.beginTransaction();
//Transient状态
user = new User();
user.setName("哈哈");
user.setPassword("234");
user.setCreateTime(new Date());
user.setExpireTime(new Date());
//persistent状态,当属性发生改变的时候,hibernate会自动和数据库同步
session.save(user);
user.setName("李鹏");
// session.update(user);
ts.commit();
} catch(Exception e) {
e.printStackTrace();
ts.rollback();
} finally {
HibernateUtils.closeSession(session);
}
//detached状态
user.setName("张三");
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//persistent状态
session.update(user);
session.getTransaction().commit();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
session.getTransaction().rollback();
} finally {
HibernateUtils.closeSession(session);
}
}
}
进入debug模式调试,查看user 的变化过程
在执行了save方法后,id被创建,也就意味着user对象被创建,但是hibernate并没有执行插入语句
之后修改user的属性也是可以的
因为在提交事务后可以看到hibernate执行了两个语句,一个insert另外一个就是update;此时也能看到数据库中已经插入记录:
update主要是由于使用了user对象的属性。
sava()操作使得它进入persistent状态,当属性发生改变的时候,hibernate会自动和数据库同步
之后的commit()执行时,进行了"脏数据检查"操作。
紧接着又关闭了session,在进入了detached状态(对象不存在于session中)。
执行到update 又转入到persistent状态。
之后提交事务,也能完成数据库的更新。
查看数据库:
之后又添加了几个测试方法,主要测试get() 和 load() 方法的不同:
public void testReadByGetMethod() {
Session session = null;
User user = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//马上发出查询sql,加载user对象
user = (User)session.get(User.class, "8a8af09123500da10123500ddb240001");
System.out.println("username" + user.getName());
//persistent状态,当属性发生改变的时候,hibernate会自动和数据库同步
user.setName("龙哥");
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
} finally {
HibernateUtils.closeSession(session);
}
}
public void testReadByGetMethod2() {
Session session = null;
User user = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//马上发出查询sql,加载user对象
user = (User)session.get(User.class, "845465756dfgdfdfgdfg001");
//persistent状态,当属性发生改变的时候,hibernate会自动和数据库同步
user.setName("龙哥");
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
} finally {
HibernateUtils.closeSession(session);
}
}
public void testReadByLoadMethod() {
Session session = null;
User user = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//不会发出查询sql,因为load方法实现了lazy(懒加载或延迟加载)
//延迟加载:只有真正使用这个对象的时候才加载(发出sql语句)
//hibernate延迟加载实现原理是代理方式
user = (User)session.load(User.class, "8a8af09123500da10123500ddb240001");
System.out.println("username = " + user.getName());
//persistent状态,当属性发生改变的时候,hibernate会自动和数据库同步
user.setName("龙哥");
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
} finally {
HibernateUtils.closeSession(session);
}
}
public void testReadByLoadMethod1() {
Session session = null;
User user = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
//采用load加载数据,如果数据库中没有相应的数据
//则抛出异常ObjectNotFoundException
user = (User)session.load(User.class, "454565555555551");
//查不到对象,则抛异常
System.out.println("username = " + user.getName());
session.getTransaction().commit();
} catch (Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
} finally {
HibernateUtils.closeSession(session);
}
}
添加工程文件到附件中。
- 大小: 3 KB
- 大小: 16.8 KB
- 大小: 2.9 KB
分享到:
相关推荐
然而,有些情况下我们并不需要完整的Session生命周期,比如执行只读操作或者简单的数据检索。在这种情况下,使用Hibernate-nosession模式可以避免创建和管理Session的开销,从而提高应用性能。nosession模式并不意味...
一级缓存默认开启,生命周期与Session相同;二级缓存可配置为共享的,跨Session有效。 9. **事务管理**:Hibernate支持编程式和声明式事务管理。编程式事务管理需要手动调用begin(), commit(), rollback()等方法,...
`SessionFactory`通常在应用启动时创建一次,然后在整个应用生命周期中复用。创建`SessionFactory`需要通过读取Hibernate配置文件(通常是`hibernate.cfg.xml`)以及实体类的映射文件(如`.hbm.xml`或使用注解)。...
在探讨如何通过`OpenSessionInViewFilter`来有效管理Hibernate中的Session生命周期之前,我们需要先理解Session及其生命周期的基本概念。 #### Session与生命周期 在Hibernate框架中,`Session`是执行数据库操作的...
5. **SessionFactory**:负责创建Session对象,它是线程安全的,一般在整个应用生命周期中只创建一次。 **操作示例** 1. **创建(Create)**:使用Session的`save()`或`persist()`方法将对象持久化到数据库。例如...
10. **实体的生命周期**:包括瞬时态、持久态、游离态和删除态,理解这些状态对于理解Hibernate的工作原理至关重要。 通过这个“Hibernate3.0_小示例”,学习者可以掌握如何设置和使用Hibernate,理解ORM的概念,...
另外,`Session`还有一系列方法用于处理对象的状态转换,如`lock()`、`merge()`、`refresh()`、`evict()`等,这些方法在处理对象生命周期的不同阶段时非常关键。 `Configuration`和`SessionFactory`也是Hibernate的...
对象的生命周期、事务的管理、数据库的存取都与 Session息息相关。Session 对象是通过 SessionFactory 构建的。 获取 Session 的两种方式 Hibernate 中获取 Session 的两种方式是:通过 HibernateUtil 工具类和...
在Hibernate中,通常在Transaction对象的生命周期内完成一组操作。如上述示例所示,开始事务、执行操作、提交事务并关闭Session。 总的来说,Hibernate的Session接口提供了一套完整的对象持久化和数据库操作机制,...
本文将详细探讨“测试实体对象的生命周期”,并结合给定的标签“源码”和“工具”,阐述如何通过Hibernate Session来理解和控制这些对象的状态。 首先,理解实体对象的生命周期对于数据库操作至关重要。在Hibernate...
在这个例子中,Spring可能用于管理Struts2 Action的生命周期,以及配置Hibernate的数据源和SessionFactory。Spring的ApplicationContext配置文件(如applicationContext.xml)定义了bean的定义和依赖关系,使得在...
在使用双向关联时,要特别注意Session的生命周期,避免出现脏读、不可重复读或幻读等并发问题。适时调用`Session.clear()`或`Session.flush()`可以帮助管理对象状态。 10. **性能优化** 虽然双向关联提供了便利,...
Hibernate merge 使用详情解说 在 Hibernate 中,merge 方法是非常重要的一个方法,它能够...然而,在使用 merge 方法时,我们需要确保对象的状态是正确的,并且需要注意 Session 的生命周期,以避免出现意外的结果。
它是线程安全的,一般在应用启动时创建一次,然后在整个应用生命周期内复用。 5. **Session**:会话对象是操作数据库的前线,通过它执行查询、保存、更新和删除操作。会话的常用方法有`save()`, `get()`, `update()...
它管理对象的生命周期和依赖关系,使得我们可以方便地实现松耦合。Spring还提供了数据访问支持,包括JDBC和ORM框架如Hibernate的集成。在本示例中,Spring可能通过XML配置文件(如beans.xml)来配置和管理服务层和...
5. **Session**:`Session`对象是执行数据库操作的主要接口,它的生命周期通常与一次用户请求或业务逻辑处理相关联。 6. **CRUD操作**: - **创建(Create)**:使用`save()`方法将对象保存到数据库。 ```java ...
在与Struts 2整合时,Spring可以作为服务层的容器,管理业务对象的生命周期和事务处理。 **Hibernate** 是一个强大的ORM(对象关系映射)框架,它允许开发者用Java对象来操作数据库,减少了SQL的直接编写,提高了...
在这里,Spring主要负责管理Bean的生命周期和组装业务层组件,同时提供事务控制,确保数据的一致性。 3. **Hibernate**:Hibernate是一个对象关系映射(ORM)框架,它简化了数据库操作,通过Java对象直接与数据库...
**Session缓存**是指在一个Session生命周期内,Hibernate用来存储已加载过的实体对象以及这些对象的状态变化的地方。Session缓存是一种一级缓存,它是每个Session独有的。 - **一级缓存**:默认情况下,每个Session...