getHibernateTemplate().saveOrUpdate(t)可以插入不能更新

2024-08-21 00:38

本文主要是介绍getHibernateTemplate().saveOrUpdate(t)可以插入不能更新,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我自己在测试毕业设计的时候,保存和更新使用的是同一个方法,老是更新不上去,不晓得怎么回事,没事就百度百度,GoogleGoogle

  • 看看
    hibernate 实体对象有三种状态
    自由状态(Transient)
    持久状态(Persistent)
    游离状态(Detached)
    关于这三种状态的区别:
    P状态 即跟session实例关联了 已经有了相对应的数据库中的主键值,所以对象处于该状态save或者updata 等都直接改变数据库中的值。
    而T状态跟D状态则不会直接改变数据库中的值,T状态是仅仅实例化一个VO对象而没有跟session实例进行任何关联则该对象处于自由状态,对于D对象则是由于与session实例相关的对象进行完持久化操作后关闭了session得到的对象状态,此时该对象有对应到数据库里的主键,可以与session实例相关把他由游离态转变为持久态。

注意:当一个对象处于持久态后被删除后,该对象虽然有数据库主键值,但是数据库中已经找不到与之相对应的记录,所以当一个持久态的对象在执行完delete方法后,就转入自由态而非游离态。游离态是该对象持有的主键可以对应到数据库里的一条记录。

我们把处于自由态和游离态的对象叫vo 而处于p状态的对象叫po
vo是相对独立的实体对象,在hibernate里处于非管理状态.
而po是有hibernate纳入到它的实体管理器的对象代表了与数据库中某条记录对应的hibernate实体po的变化在事务提交时将反应到实际的数据库中。
如果一个po与session实例分离那么此时它就变为一个vo。
为了避免在项目开发的过程在表示层出现po传值 .可以用Apache jakarta Commons Beanutils 的复制属性的方法。
举例说明:

Tuser user = new Tuser(); 
Tuser anotherUser =new Tuser(); try{ Beantils.copyProperties(anotherUser,user); System.out.println(antherUser.getName()); 
}catch(IllegalAccessExption e){ 
e.peintStackTrace(); 
} 

我的t对象就是处于Session中,持久化状态,已经在Session中存储过了,所以继续寻找,寻到了csdn论坛上关于getHibernateTemplate().flush();的解释
这跟线程有关系,应该是spring使用是ThreadLocal ,一个线程对应一个session,可能是你在同个线程下多次调用 了update,update操作的是游离状态,而出问题的情况下应该是你的session里面已经有一个持久态的userInfo,而更新持久态是要用flush
所以flush()就是刷新缓存……

这篇关于getHibernateTemplate().saveOrUpdate(t)可以插入不能更新的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1091632

相关文章

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

C#实现插入与删除Word文档目录的完整指南

《C#实现插入与删除Word文档目录的完整指南》在日常的办公自动化或文档处理场景中,Word文档的目录扮演着至关重要的角色,本文将深入探讨如何利用强大的第三方库Spire.Docfor.NET,在C#... 目录Spire.Doc for .NET 库:Word 文档处理利器自动化生成:C# 插入 Word

MySQL 批量插入的原理和实战方法(快速提升大数据导入效率)

《MySQL批量插入的原理和实战方法(快速提升大数据导入效率)》在日常开发中,我们经常需要将大量数据批量插入到MySQL数据库中,本文将介绍批量插入的原理、实现方法,并结合Python和PyMySQ... 目录一、批量插入的优势二、mysql 表的创建示例三、python 实现批量插入1. 安装 PyMyS

Java轻松实现在Excel中插入、提取或删除文本框

《Java轻松实现在Excel中插入、提取或删除文本框》在日常的Java开发中,我们经常需要与Excel文件打交道,当涉及到Excel中的文本框时,许多开发者可能会感到棘手,下面我们就来看看如何使用J... 目录Java操作Excel文本框的实战指南1. 插入Excel文本框2. 提取Excel文本框内容3

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种