首页 > 数据库 >JPA查询修改数据,但是未保存到数据库,数据库却修改了,因为对查询出的Entity实体对象,修改set了属性。导致事务提交时候修改了数据库的数据

JPA查询修改数据,但是未保存到数据库,数据库却修改了,因为对查询出的Entity实体对象,修改set了属性。导致事务提交时候修改了数据库的数据

时间:2023-10-23 13:00:11浏览次数:41  
标签:状态 对象 数据库 查询 修改 JPA

JPA查询修改数据,但是未保存到数据库,数据库却修改了,因为对查询出的Entity实体对象,修改set了属性。导致事务提交时候修改了数据库的数据

使用JPA查询数据,对查询出来的结果进行修改,但是不保存数据库,最终数据库却做了同样的修改。

JPA对象的四种状态

瞬时状态:瞬时状态的实体就是一个普通的java对象,一般为新new出来的实体,没有id,没有和数据库建立练习

托管状态:使用jpa查询出来的对象,例如findById查询返回的对象,此时对象已经持久化,有id,并且和数据库建立了联系,此时修改对象的属性值会被同步到数据库中

在这里插入图片描述
在这里插入图片描述

没有进行save操作,但是此时数据库中的值已经发生改变了

游离状态:当事务提交后,处于托管状态的对象就转变为了游离状态。此时该对象仍有id,但是不在持久化中因此任何对于该对象的修改都不会同步到数据库中。

删除状态:当调用jpa中的方法例如delete对实体进行delete后,该实体对象就处于删除状态。其本质也就是一个瞬时状态的对象。

具体的操作可以看我们代码中的业务,如果我们忘记在最后执行.save方法,此时做修改数据库中的数据是会发生改变的(除第一次保存外)

原文链接:https://blog.csdn.net/scdn_wyy/article/details/124453179

标签:状态,对象,数据库,查询,修改,JPA
From: https://www.cnblogs.com/sunny3158/p/17782168.html

相关文章

  • Transformer王者归来!无需修改任何模块,时序预测全面领先
    前言 最近,来自清华大学和蚂蚁集团的研究人员重新审视Transformer结构在时序分析中的应用,提出一个全新的反转视角——无需修改任何模块,即可实现Transformer在时序预测任务上的全面领先!本文转载自新智元仅用于学术分享,若侵权请联系删除欢迎关注公众号CV技术指南,专注于计算机视觉......
  • 软件设计之C/S结构连接数据库实现登录功能
    界面展示具体代码//DBUtil.javapackageorg.example;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.SQLException;publicclassDBUtil{publicstaticConnectiongetConnection()throwsClassNotFoundException,SQLException......
  • mysql数据库类型有哪些
    mysql数据库类型有哪些mysql数据库类型有:1、整数类型;2、浮点数类型;3、定点数类型;4、位类型BIT;5、日期与时间类型;6、文本字符串类型;7、ENUM类型;8、SET类型;9、二进制字符串类型;10、JSON类型;11、空间类型。其中,整数类型一共有5种。1、整数类型整数类型一共有5种,包括TINYI......
  • Oracle数据库表空间和角色/用户 权限
    问题1.2.3.https://www.iteye.com/blog/czmmiao-1304934这个特别好4.5.6.https://www.51cto.com/article/158937.html表空间7.创建用户8.表空间9.oracle体系结构详解10.https://zhuanlan.zhihu.com/p/100390025实例、表空间、用户之间的关系11.https://docs.oracle......
  • PowerBuilder读取硬盘图片显示出来并保存到数据库中
    PowerBuilder读取硬盘图片显示出来并保存到数据库中 数据库是SQLSERVER 表:blobtab 列: id,int,主键自增 blobdata,image,二进制内容可空 注:PB中存储二进制数据和读取二进制数据只能用updateblob语句和selectblob语句  显示图片到控件里的代码://显......
  • Chromium源码 修改默认搜索引擎及标签页
    默认新标签页修改方法:1.找到chrome/browser/ui/browser_tabstrip.cc文件找到变量NavigateParamsparams:1NavigateParamsparams(browser,url.is_empty()?browser->GetNewTabURL():url,2ui::PAGE_TRANSITION_TYPED);修改为:1NavigatePara......
  • MyBatis-Plus和shardingsphere一起用。子查询取别名读取不到的问题。
    https://github.com/baomidou/mybatis-plus/issues/2585在使用MP和Shardingsphere的某些版本中,可能会出现join子查询表取别名之后,在where中用这个别名报错 Cannotfindownerfromtable.//重点是外层SQL不要出现*,不要使用别名,需要的字段都写清楚(内外层sql都要写清楚),......
  • jmeter操作数据库
    数据库连接配置组件:参数配置:数据库请求配置组件:请求配置: ......
  • 数据库——基本概念
    1、什么是数据库?数据库,DataBase,简称db,存储数据的仓库。按照一定格式存储数据的一些文件的组合。2、什么是数据库管理系统?数据库管理系统,DataBaseManagementSystem,简称DBMS,管理数据库的系统,可以对数据库中的数据进行增删改查。常用的数据库管理系统有:Mysql、Oracle、SqlServer......
  • oracle查询执行过sql语句
    一、oracle中查找某段时间执行的操作记录selectsql_text,module,first_load_timefromv$sqlareawherefirst_load_time>'2019-02-02/02:02:02'andfirst_load_time<'2019-02-02/02:02:02'orderbyfirst_load_time二、查看某一时间的执行过的所有sqlselect......