Hibernate Session中的save(),update(),delete(),saveOrUpdate() 细粒度分析

Hibernate在对资料库进行操作之前,必须先取得Session实例,相当于JDBC在对资料库操作之前,必须先取得Connection实例, Session是Hibernate操作的基础,它不是设计为执行绪安全(Thread-safe),一个Session由一个执行绪来使用。

  • 开启Session

Session实例由SessionFactory开启获得,例如:

Configuration config = new Configuration().configure();

SessionFactory sessionFactory = config.buildSessionFactory();

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

....

tx.commit();

session.close();

开启Session不会马上取得Connection,而是在最后真正需要连接资料库进行更新或查询时才会取得Connection,如果有设定User user = new User();

user.setName("momor");

user.setAge(new Integer(26));

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

session.save(user);

tx.commit();

session.close();

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

User user = (User) session.get(User.class, new Integer(1));

tx.commit();

session.close();

如果未能发现相符合的资料,则get()方法会返回null,而load()方法会丢出ObjectNotFoundException,在进阶的应用中,load()方法可以返回代理(proxy)物件,在必要时才真正查询资料库取得对应资料,并可充分利用快取机制。

在Hibernate 3中,取消了find()方法,您必须透过Query或Criteria来进行资料查询。

  • 删除资料

接下来看看使用Session删除资料,可使用delete()删除资料:

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

User user = (User) session.get(User.class, new Integer(1));

session.delete(user);

tx.commit();

session.close();

  • 更新资料

当您在同一个Session中取出资料并封装为Persistence Object,接着更新物件状态,而后将Transaction commit,则物件上的状态更新将反应至资料库中,您无需额外进行任何的更新操作。

如果您开启了一个Session,从资料表中取出资料显示到使用者介面上,之后关闭Session,当使用者在介面上操作完毕并按下储存时,这时您要重新开启一个Session,使用update()方法将物件中的资料更新至对应的资料表中:

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

User user = (User) session.get(User.class, new Integer(2));

tx.commit();

session.close();

....

user.setAge(new Integer(27));

session = sessionFactory.openSession();

tx= session.beginTransaction();

session.update(user);

tx.commit();

session.close();

Session提供了一个saveOrUpdate()方法,为资料的储存或更新提供了一个统一的操作介面,藉由定义映射文件时,设定< id>标签的unsaved-value来决定什么是新的值必需,什么是已有的值必须更新:

<id name="id" column="id" type="java.lang.Integer" unsaved-value="null">

<generator class="native"/>

</id>

unsaved-value可以设定的值包括:

  • any:总是储存
  • none:总是更新
  • null:id为null时储存(预设)
  • valid:id为null或是指定值时储存

这样设定之后,您可以使用Session的saveOrUpdate()方法来取代update()方法。

  • 合并状态

以这边的例子来说:

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

User user1 = (User) session.get(User.class, new Integer(2));

tx.commit();

session.close();

....

user1.setAge(new Integer(27));

session = sessionFactory.openSession();

tx= session.beginTransaction();

User user2 =(User) session.get(User.class, new
Integer(2)); // 同一个id

// user1 == user2 为 false

session.update(user1); // 丢出NonUniqueObjectException

tx.commit();

session.close();

在进行update()之前,您就先从资料库中取得另一笔资料,之后再尝试更新user1,由于目前的Persistence
context已载入一笔资料,并有同一个id的User 实例了,同一个Persistence
context不会有两个相同id的物件实例,因此丢出NonUniqueObjectException。

就这边的例子来说,您应该使用merge()而不是update():

Session session = sessionFactory.openSession();

Transaction tx = session.beginTransaction();

User user1 = (User) session.get(User.class, new Integer(2));

tx.commit();

session.close();

....

user1.setAge(new Integer(27));

session = sessionFactory.openSession();

tx= session.beginTransaction();

User user2 =(User) session.get(User.class, new Integer(2)); // 同一个id

User user3 = (User) session.merge(user1);

// user1 == user2 为 false

// user2 == user3 为 true

tx.commit();

session.close();

merge()会将user1与user2的状态合并,传回的物件实例就是user2原先所参考的实例。

时间: 2024-10-12 08:31:13

Hibernate Session中的save(),update(),delete(),saveOrUpdate() 细粒度分析的相关文章

hibernate session中的load与get

一.get不支持lazy,load支持lazy. 二.采用get加载数据,如果没有匹配的数据,返回null,而load则抛出异常. 三.执行load()时,先从Session查找当前的对象是否存在,如果不存在,则从数据库中去查询,如果不存在这条记录,则扔异常:执行get()的时候,不论Session中是否存在当前对象,直接从数据库中去查询,如果不存在,则返回null. 四.load()方法可以返回实体的代理类实例,而get()永远只返回实体类. get的例子: public void testG

SQL Server 2008中SQL增强之三:Merge(在一条语句中使用Insert,Update,Delete)

SQL Server 2008提供了一个增强的SQL命令Merge,用法参看MSDN:http://msdn.microsoft.com/zh-cn/library/bb510625.aspx 功能:根据与源表联接的结果,对目标表执行插入.更新或删除操作.例如,根据在另一个表中找到的差异在一个表中插入.更新或删除行,可以对两个表进行同步. 我们看一个例子,假如,有一总产品列表,一个分店产品列表,需要从分店添加产品时更新总产品列表. 总产品表,分店产品表结构完全一致: if OBJECT_ID('

SQL Server 2008中SQL增强之三:Merge(在一条语句中使用Insert,Update,Delete) 一条语句实现两表同步(添加、删除、修改)

MERGE 目标表 USING 源表 ON 匹配条件 WHEN MATCHED THEN 语句 WHEN NOT MATCHED THEN 语句; http://www.chinaz.com/program/2010/1014/137713.shtml

Hibernate Session &amp; Transaction详解

Hibernate Session & Transaction详解 HIbernate中的Session Session是JAVA应用程序和Hibernate进行交互时使用的主要接口,它也是持久化操作核心API, 注意这里的Session的含义,它与传统意思上web层的HttpSession并没有关系,Hibernate Session之与Hibernate,相当于JDBC Connection相对与JDBC. Session对象是有生命周期的,它以Transaction对象的事务开始和结束边界

Hibernate Session的save()、update()、merge()、lock()、saveOrUpdate()和persist()方法分别是做什么的?有什么区别?

session的方法: save(): insert 调用save方法之后,瞬时态对象可以变成持久态: update():update 将游离态对象变为持久态 saveOrUpdate():insert or update merge(): merge()方法可以完成save()和update()方法的功能,它的意图是将新的状态合并到已有的持久化对象上或创建新的持久化对象. 将游离态对象变为持久态. lock(): lock()方法是把一个没有更改过的脱管状态的对象变成持久状态. persisi

hibernate中 saveorupdate(),save(),update(),merge()你是怎么看待的;

接触到mybatis竟然有把hibernate抛弃的想法. 言归正传,贴图为先.hibernate的三种状态位和切换之间对函数的使用: 总结下saveorupdate(),save(),update(),merge()这几个函数: save(),update():都是很好理解的 save()在数据库中生成一条记录,如果数据库中有,会报错说有重复的记录. update()就是更新数据库中的记录: merge()就非常奇葩: 1.如果session中存在相同持久化标识(identifier)的实例,

Hibernate三种状态的区分,以及save,update,saveOrUpdate,merge等的使用 ----转----

Hibernate三种状态的区分,以及save,update,saveOrUpdate,merge等的使用 Hibernate的对象有3种状态,分别为:瞬时态(Transient). 持久态(Persistent).脱管态(Detached).处于持久态的对象也称为PO(Persistence Object),瞬时对象和脱管对象也称为VO(Value Object). 瞬时态         由new命令开辟内存空间的java对象, eg. Person person = new Person(

Hibernate三种状态的区分,以及save,update,saveOrUpdate,merge等的使用

Hibernate三种状态的区分,以及save,update,saveOrUpdate,merge等的使用 Hibernate的对象有3种状态,分别为:瞬时态(Transient). 持久态(Persistent).脱管态(Detached).处于持久态的对象也称为PO(Persistence Object),瞬时对象和脱管对象也称为VO(Value Object). 瞬时态         由new命令开辟内存空间的java对象, eg. Person person = new Person(

hibernate save,update,saveorupdate方法有什么区别

save肯定是添加的时候用,update修改时候用,saveorupdate是添加或修改,如果真是这样save和update的存在就没意义了,我们直接saveorupdate就行了. save在添加用的时候 不会出现索引机制(即遍历目录 效率最高)update在修改时候要遍历 不存在则会异常saveorupdate是优先遍历 如果不存在则创建(效率最低)merge和saveOrUpdate方法区别在于:merge方法是把我们提供的对象转变为托管状态的对象:而saveOrUpdate则是把我们提供