jpa删除数据后数据库无修改_JPA查询数据并操作数据未保存到数据库,但是数据库中已经修改...

jpa中的对象有四种状态:

瞬时状态:瞬时状态的实体就是一个普通的java对象,和持久化上下文无关联,数据库中也没有数据与之对应。

托管状态:使用EntityManager进行find或者persist操作返回的对象即处于托管状态,此时该对象已经处于持久化上下文中,因此任何对于该实体的更新都会同步到数据库中。

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

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

-----------------------------------------------

出现数据库的数据改变的情况就说明你的实体对象处于托管状态,将托管状态变成游离状态即可!

如何实现?

方案一:

@PersistenceContext

private EntityManager entityManager;

//查询数据库的方法

entityManager.clear();

设置游离状态

方案二:

新建一个DTO,DTO中的内容和实体类中的保持一致,将实体类中的内容赋值给DTO即可,操作DTO,数据库查询用实体类,数据操作用DTO!

个人比较推荐第一种,毕竟简单粗暴!

感觉还是mybatis plus好用!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 在Spring Boot,可以使用JdbcTemplate或者Spring Data JPA等方式从数据库查询数据。 2. 假设我们从数据库查询出以下数据: ```java List<Map<String, Object>> dataList = jdbcTemplate.queryForList("SELECT name, age, city FROM user"); ``` 3. 将查询结果转化为指定格式的数据: ```java List<Map<String, Object>> formattedDataList = new ArrayList<>(); for (Map<String, Object> data : dataList) { Map<String, Object> formattedData = new LinkedHashMap<>(); formattedData.put("name", data.get("name")); formattedData.put("age", data.get("age")); formattedData.put("city", data.get("city")); formattedDataList.add(formattedData); } ``` 4. 将数据传递给Thymeleaf模板引擎,在index.html进行展示。 Controller代码: ```java @GetMapping("/") public String index(Model model) { List<Map<String, Object>> dataList = jdbcTemplate.queryForList("SELECT name, age, city FROM user"); List<Map<String, Object>> formattedDataList = new ArrayList<>(); for (Map<String, Object> data : dataList) { Map<String, Object> formattedData = new LinkedHashMap<>(); formattedData.put("name", data.get("name")); formattedData.put("age", data.get("age")); formattedData.put("city", data.get("city")); formattedDataList.add(formattedData); } model.addAttribute("dataList", formattedDataList); return "index"; } ``` index.html代码: ```html <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <title>Spring Boot Thymeleaf Example</title> </head> <body> <h1>Data List</h1> <table> <thead> <tr> <th>Name</th> <th>Age</th> <th>City</th> </tr> </thead> <tbody> <tr th:each="data : ${dataList}"> <td th:text="${data.name}"></td> <td th:text="${data.age}"></td> <td th:text="${data.city}"></td> </tr> </tbody> </table> </body> </html> ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值