gpt4 book ai didi

mysql - Spring Boot Jpa - 如何将实体更新到 mysql 数据库

转载 作者:行者123 更新时间:2023-11-29 09:38:54 24 4
gpt4 key购买 nike

我想更新 Employee 实体,但它不起作用,它只是将实体添加到表中而不是更新它。

Controller

@PutMapping("updateEmployee/{id}")
public void updateEmployee(@PathVariable long id, @RequestBody Employee employee) {
employeeService.updateEmployee(id, employee);
}

连接到 JpaRepository 的服务

public void updateEmployee(long id, Employee employee) {
employeeRepository.save(employee);
}

最佳答案

在 Spring Data JPA(使用 Hibernate)中更新实体的常见做法是:

  1. 读取实体,
  2. 更新其属性,
  3. 关闭交易。

例如:

@Service
public class EmployeeService {

@Autowired private EmployeeRepo repo;

@Transactional
public Optional<Employee> update(long employeeId, Employee source) {
return repo.findById(employeeId).map(target -> {
target.setName(source.getName());
// update other props...
return target;
});
}
}

因此,当事务关闭时,Hibernate 将自动更新数据库中的实体 - 不需要 save 方法调用。

关于mysql - Spring Boot Jpa - 如何将实体更新到 mysql 数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57075120/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com