我有一个要求,我根据uuid更新行,其中一个uuid可能与多个行相关联。
以下是该方案: 4a90558c-4a5b-4af7-8c68-60ff81f74ef3是我的uuid,它存在于我的数据库的8列中。
我的java代码如下:
try{
session = sessionFactory.getCurrentSession();
tx = session.getTransaction();
criteria = session.createCriteria(Archive.class);
criteria.add(Restrictions.eq("bagUuid", "4a90558c-4a5b-4af7-8c68-60ff81f74ef3"));
ScrollableResults items = criteria.scroll();
while ( items.next() ) {
Archive archive = (Archive)items.get(0);
archive.setDecision(1);
archive.setOperatorAssigned("test");
session.saveOrUpdate(archive);
session.flush();
session.clear();
}
tx.commit();
LOGGER.info("Archive Record is updated: "+archive.getFilePath());
}catch(Exception e){
recordUpdated = false;
tx.rollback();
LOGGER.error("Archive Record failed to update due to exception in updateArchiveRecord method: "+e.getMessage());
}
有时,与UUID相关的所有记录都在更新,但有时会失败。 我认为这可能是Hibernate API的一个问题。 是否有其他人遇到过同样的问题。
答案 0 :(得分:2)
这一行看起来很可疑:
Archive archive = (Archive)items.get(0);
这意味着无论ScrollableResults中的项目数是多少,您都只会更新第一个Archive对象。如果我理解你正在尝试做什么,它应该是当前的记录:
Archive archive = (Archive)items.get();
另外,我将移出/删除session.flush()和session.clear()。最终代码如下所示:
try{
session = sessionFactory.getCurrentSession();
tx = session.getTransaction();
criteria = session.createCriteria(Archive.class);
criteria.add(Restrictions.eq("bagUuid", "4a90558c-4a5b-4af7-8c68-60ff81f74ef3"));
ScrollableResults items = criteria.scroll();
while ( items.next() ) {
Archive archive = (Archive)items.get();
archive.setDecision(1);
archive.setOperatorAssigned("test");
session.saveOrUpdate(archive);
}
tx.commit();
session.close();
LOGGER.info("Archive Record is updated: "+archive.getFilePath());
}catch(Exception e){
recordUpdated = false;
tx.rollback();
LOGGER.error("Archive Record failed to update due to exception in updateArchiveRecord method: "+e.getMessage());
}
Slava Imeshev