【发布时间】:2017-02-06 01:20:28
【问题描述】:
因此,我查看了有关使用 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,它在服务层中检索,然后交给控制器/客户端。
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 中更改他的名称 - 然后会有一些控制器操作,其中将有更新的 DTO 与旧 ID 和新名称。
现在我必须将这个更新的 DTO 保存到数据库中。
不幸的是,目前没有办法更新现有客户(除了删除数据库中的条目并使用新的自动生成的 id 创建一个新的客户)
但是,由于这是不可行的(特别是考虑到这样一个实体可能有数百个关系) - 所以我想到了 2 个直截了当的解决方案:
- 为 Customer 类中的 id 创建一个设置器 - 从而允许设置 id,然后通过相应的存储库保存 Customer 对象。
或
- 将 id 字段添加到构造函数中,每当您想要更新客户时,您始终使用旧 id 创建一个新对象,但其他字段的新值(在这种情况下只有名称)
所以我的问题是是否有一般规则如何做到这一点? 我解释的两种方法的缺点是什么?
【问题讨论】:
-
“所以目前没有办法更新现有客户(除了删除数据库中的条目并使用新的自动生成的 id 创建一个新的客户)”Say... what?。您是如何想到这个想法的?
-
如果您使用相同的 ID 调用
save()并且您没有覆盖它,它会给您一个重复 ID 异常。如果您已正确配置 Spring Transactions,那么每当您从数据库中获取客户并简单地设置所需的值时,您会看到一些查询将被写入日志中。但是仍然让我们在没有 JPA 的情况下考虑它,在您的场景中,通常如何使用简单的 sql 更新客户行????如果你没有身份证???? -
我稍后会补充一些澄清,感谢您的 cmets
-
我更新了问题以使其更清晰
-
您可以删除
strategy = GenerationType.AUTO,因为它是默认的。@Column(name = "id")与id属性完全相同。
标签: java spring jpa spring-data spring-data-jpa