• save与 merge与 saveOrUpdate的区别


    save()方法很显然是执行保存操作的,如果是对一个新的刚new出来的对象进行保存,自然要使用这个方法了,数据库中没有这个对象。

    update()如果是对一个已经存在的托管对象进行更新那么肯定是要使用update()方法了,数据中有这个对象。

    saveOrUpdate()这个方法是更新或者插入,有主键就执行更新,如果没有主键就执行插入。

    区别:对于一个从托管状态到瞬态的对象(对于一个从数据库中取出来又被删除的对象),这个对象本身是有主键的,但是因为被删除了,

    所以这个时候因为数据库中已经没有了这条记录了。不过它还有主键存在,所以这个时候不可以使用update()或者是saveOrUpdate(),

    因为update()方法是认为数据库中肯定有这条记录的,而saveOrUpdate的执行过程就是先查看这个对象是不是有主键,有主键那么就执行

    update()方法,没有主键就执行save()方法,因此结果跟调用了update()方法的效果是一样的,结果就会出错,因为这个对象已经被删除了,

    数据库中已经没有这条记录了,只是它还有主键而已(仅仅是存在于内存中),因此这个时候要执行的是save()方法。

    **********************************************************************************************

    一、save()和persist()将会引发SQL的INSERT,delete()会引发SQLDELETE,
    而update()或merge()会引发SQL UPDATE。对持久化(persistent)实例的修改在刷新提交的时候会被检测到,它也会引起SQL UPDATE。
    saveOrUpdate()或者replicate()会引发SQLINSERT或者UPDATE
    二、save 和update区别
    把这一对放在第一位的原因是因为这一对是最常用的。
    save的作用是把一个新的对象保存
    update是把一个脱管状态的对象或自由态对象(一定要和一个记录对应)更新到数据库

    三、update 和saveOrUpdate区别
    这个是比较好理解的,顾名思义,saveOrUpdate基本上就是合成了save和update,而update只是update;引用hibernate reference中的一段话来解释他们的使用场合和区别
    通常下面的场景会使用update()或saveOrUpdate():
    程序在第一个session中加载对象,接着把session关闭
    该对象被传递到表现层
    对象发生了一些改动
    该对象被返回到业务逻辑层最终到持久层
    程序创建第二session调用第二个session的update()方法持久这些改动

    ********************************************************************************************************************

  • 相关阅读:
    protobuf自解释message
    protobuf编码
    proto3语法
    proto2语法
    protobuf简介
    poi处理大EXCEL文件总结
    POI-处理大Excel文件(xlsx写)
    POI-处理大Excel文件(xlsx)
    POI-处理大Excel文件(xls)
    RedHat 6.4 RHCS GFS2安装
  • 原文地址:https://www.cnblogs.com/ainiaiwo/p/5826681.html
Copyright © 2020-2023  润新知