a different object with the same identifier value

今天在作excel导入的时候碰到的问题,
excel里面的记录往数据库录入的过程中,如果存在就update,不存在就save于是在操作数据库前分别将2个不同性质的bean放到saveList和updateList依次调用
saveOrUpdateByList(List list)方法

public synchronized int saveOrUpdateByList(List listObj){
int count = 0;
Session session = null;
try {
if(listObj != null && !listObj.isEmpty()){
session = getSession();
for(int i = 1;i<=listObj.size();i++){
session.saveOrUpdate(listObj.get(i-1)); count++;
if(i%20 == 0){
session.flush();
session.clear();
}
}
}
} catch (Exception e) {
e.printStackTrace();
}finally{
if(session != null){
session.flush();
session.clear();
releaseSession(session);
}
}
return count;
}

老是报错a different object with the same identifier value was already associated with the session
查了下网站,说用merge()方法,就把方法中的
session.saveOrUpdate(listObj.get(i-1));

改成
session.saveOrUpdate(session.merge(listObj.get(i-1)));

就好了,
解决总归解决,本来想上eye论坛探讨下问题出现的原因以及这样解决的办法,不过弱弱的理论还是让我放弃了,怕跟不散大家的思路呀...
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值