saveTrackInfoAll(obj,null,mergFlag);
getHibernateTemplate().saveOrUpdate(obj);
getHibernateTemplate().flush();
getHibernateTemplate().refresh(obj); 在用以上方式进行hibernate保存对象时,报如下错误:
Caused by: org.hibernate.UnresolvableObjectException: No row with the given identifier exists: [flex.esb.model.EsbMessageRecord#18090237664875]
该问题是因为原代码中: esbMessageRecord.setId(new BigDecimal(generateSeqId)); 封装对象时,添加了id,而实体类中id是自增主键@Id
@GeneratedValue(generator = "dateAndIpSequence")
@GenericGenerator(name = "dateAndIpSequence", strategy = "flex.common.hibernate.IDGenerator")
public BigDecimal getId() {};
最近使用hibernate保存数据的时候,没有使用id自增主键,而是使用了一种调用seq以后手动赋值的方式生成主键,然后使用saveorupdate()报错。上网查看终于知道了问题所在,记录一下:
在单主键情况,save()和saveorupdate()到底有啥区别:
如果持久对象使用了自增长的单主键(一般情况下也都是这么做)。通常两者没什么区别。
但是如果持久对象使用自己赋值的单主键,那么使用saveOrUpdate就不大合适了。
例如:如果你将一个持久对象的主键赋值了,你本想插入这条记录,但实际上执行的是更新,因为hibernate会认为你的主键存在了,那么它会采用更新。但如果你使用save,那么hibernate直接插入数据。也就是对象中有id如果执行方法saveorupdate那么就是更新操作,但是此时如果数据库中没有该数据就会报错。解决方法:去掉id手动赋值。