关于spring jpa save更新的操作

现有一个entity如下
@Entity
@Table(name = "t_pcstatus")
public class PCStatusEntity {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int statusId;
private int webId;
private String ipAddr;
private String lastSigninDate;

我想通过ipAddr的唯一ip更新操作,使用如下方式
pcStatusEntity = new PCStatusEntity();
pcStatusEntity.setIpAddr(requestIP);
int webId = jsonSignIn.getInt("web_id");
pcStatusEntity.setWebId(webId);
pcStatusEntity.setLastSigninDate(curDate);
pcStatusService.savePCStatus(pcStatusEntity);


然而控制台却报了一个错误
 Duplicate entry '127.0.0.1' for key 'ip_addr'


经过google大神的指教,发现了问题,spring jpa的save操作在底层是先执行merge()的一个动作,而执行merge动作时根据entity标签里面的@Id,也就是主键来区分的,所以正确的更新方式应该是先把entity查询出来,然后再更新其中的某个字段,或者指教采用@Query的原生sql方式。
参考地址 [url]http://stackoverflow.com/questions/11881479/how-do-i-update-an-entity-using-spring-data-jpa[/url]

你可能感兴趣的:(关于spring jpa save更新的操作)