我有一个客户对象,在该客户对象中,我有一个包含用户名和密码的登录对象。当我执行 POST 时,请求工作正常,但是当我尝试执行 PUT 请求时,它会失败。它失败,因为它在用户名上显示重复条目。
我希望能够在不更改用户名的情况下更新客户详细信息。我怎样才能做到这一点。
这是我的代码:
用户登录实体 :
@Entity
@Table(name = "Customer",
uniqueConstraints =
{
@UniqueConstraint(columnNames = "email"),
@UniqueConstraint(columnNames = "id"),
@UniqueConstraint(columnNames = "phoneNumber")
}
)
public class Customer implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int customerNumber;
@OneToOne(cascade= CascadeType.ALL)
@JoinColumn(name = "loginCredentialsID")
private UserLogin userlogin;
private String phoneNumber;
private String email;
private String physicalAddress;
private String country;
... getters and setters
}
用户登录实体 :
@Entity
@Table(name = "UserLogin",
uniqueConstraints =
{
@UniqueConstraint(columnNames = "userName")
})
public class UserLogin implements Serializable, UserDetails {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int loginCredentialsID;
private String username;
private String password;
... getters and setters
}
客户服务等级 :
public Response updatCustomeretails(int id,Customer customer) {
customer.setCustomerNumber(id);
if( customer== null ){
throw new ResourceNotFoundException("Empty", "Missing Data");
}else {
customerRepository.save(customer);
return new Response(" Customer Updated Successfully","Thank you ");
}
使用Sping 数据 JPA 进行更新时,您应该使用 save 时正确执行的保存customerRepository.save(customer);
.但是,在 PUT 请求中将数据保存到数据库时,JPA 使用实体映射中的键来更新正确的记录。
因此,在您的情况下,当 JPA 尝试保存新记录而不是更新现有记录时,您会收到该错误。您打算更新,但我怀疑您的键丢失或未正确定义,因此 JPA 尝试保存新记录而不是更新。
因此,当您执行更新(PUT)时,请确保您传递的对象与要更新的对象具有相同的键。