- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
因此,我查看了有关使用 Spring Data 的 JPA 的各种教程,并且在很多情况下都做了不同的处理,我不太确定正确的方法是什么。
假设存在以下实体:
package stackoverflowTest.dao;
import javax.persistence.*;
@Entity
@Table(name = "customers")
public class Customer {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id")
private long id;
@Column(name = "name")
private String name;
public Customer(String name) {
this.name = name;
}
public Customer() {
}
public long getId() {
return id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
我们还有一个 DTO,它在服务层中检索,然后交给 Controller /客户端。
package stackoverflowTest.dto;
public class CustomerDto {
private long id;
private String name;
public CustomerDto(long id, String name) {
this.id = id;
this.name = name;
}
public long getId() {
return id;
}
public void setId(long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
所以现在假设客户想要在 webui 中更改他的名字 - 然后会有一些 Controller 操作,其中将有更新的 DTO 与旧 ID 和新名称。
现在我必须将这个更新的 DTO 保存到数据库中。
不幸的是,目前没有办法更新现有客户(除了删除数据库中的条目并使用新的自动生成的 id 创建一个新的客户)
但是由于这是不可行的(特别是考虑到这样的实体可能有数百个关系) - 所以我想到了 2 个直截了当的解决方案:
或
所以我的问题是是否有一般规则如何做到这一点?我解释的两种方法的缺点是什么?
最佳答案
比@Tanjim Rahman 回答更好,您可以使用 Spring Data JPA 使用方法 T getOne(ID id)
Customer customerToUpdate = customerRepository.getOne(id);
customerToUpdate.setName(customerDto.getName);
customerRepository.save(customerToUpdate);
更好,因为 getOne(ID id)
gets you only a reference (代理)对象,并且不从数据库中获取它。在这个引用上,你可以设置你想要的,在 save()
上它会像你期望的那样做一个 SQL UPDATE 语句。相比之下,当您调用 find()
时,如@Tanjim Rahmans 回答 spring data JPA 将执行 SQL SELECT 以从数据库中物理获取实体,当您只是更新时,您不需要。
关于java - 如何在 Spring Data 中漂亮地更新 JPA 实体?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39741102/
我是一名优秀的程序员,十分优秀!