关于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]
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值