我有一个需要保存到数据库表中的 DTO 类列表。由于某些我无法跟踪的未知原因,只有最后一项被保存到数据库中。
在下面找到示例服务和管理器类,
class TestService {
public void saveData(List<OrderDTO> dtolist) {
//exception handling properly
transaction.begin();
manager.saveAlldata(dtolist);
transaction.commit();
}
}
Class TestManager {
public void saveAlldata(List<OrderDTO> dtolist) {
//exception handles properly
for(OrderDTO dto: dtolist){
OrderPersist persist = new OrderPersistent();
persist.setId(dto.getId());
persist.setItem(dto.getItem());
//save(persist) or merge(persist);
}
}
假设我有 2 个项目详细信息,例如dto 列表中的 id=1、Item=S_001 和 Id=2、Item=S_002 则仅将最后一项(2、S_002)保存到表中。
最佳答案
你试过这个吗?
public void saveAlldata(List<OrderDTO> dtolist) {
//exception handles properly
for(OrderDTO dto: dtolist){
transaction.begin();
OrderPersist persist = new OrderPersistent();
persist.setId(dto.getId());
persist.setItem(dto.getItem());
//save(persist) or merge(persist);
transaction.commit();
}
}
关于java - hibernate 事务 : Only Last item of list is saved into the table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39118482/