关于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方式。
参考地址 http://stackoverflow.com/questions/11881479/how-do-i-update-an-entity-using-spring-data-jpa

你可能感兴趣的:(spring)