我在我的項目中使用 Spring boot 1.5.22、Spring data 和 Hibernate 5.2.18。當我使用 Dao 保存實體對象時:platDao.save(plat);數據庫中正在執行 BEFORE INSERT 類型的觸發器,該觸發器正在數據庫字段中插入多個文檔。當我在數據庫工具中使用 SQL 從數據庫中的表中進行選擇時,我可以看到該字段中的值。但是當我使用 hibernate 和 findOne 方法獲取此記錄時,我在此字段中看到 null:Platnosc plat = platDao.findOne(platId);我也嘗試過這個:Platnosc plat = platDao.findById(platId);但結果是一樣的,觸發器設置的字段為空。我的服務代碼:public List<Platnosc> createDocumentForInvoice(Integer fakturaId) { AuthUser user = loginMgr.getLoggedUser(); Platnosc plat = Platnosc.builder() // I don't set field platnoscNr here it is null .build(); platDao.save(plat); return plat;}我的控制器的代碼:public Response createDocumentForInvoice( @RequestParam(value = "fakturaId", required = true) Integer fakturaId) { List<Platnosc> platList = platMgr.createDocumentForInvoice(fakturaId); // after this I can see in database value of field platnoscNr which was inserted by trigger String platNr = platList.stream() .map(p -> { Platnosc plat = platDao.findById(p.getPlatnoscId()); return String.format("%s nr %s", platMgr.getRodzajTextForPlatnoscRodzaj(plat.getPlatnoscRodzaj()), plat.getPlatnoscNr()); }) .collect(Collectors.joining(", ")); return Response.ok(platList.size() == 0 ? "No document was created" : "Created documents: " + platNr) .build();}回應是:“已創建的文檔:信用卡編號為空,轉賬編號為空,其他付款編號為空”
2 回答

慕俠2389804
TA貢獻1719條經驗 獲得超6個贊
為了查看觸發器所做的更改,我在 platDao.save(plat) 之后在服務中添加了兩行代碼:
實體管理器.flush();
EntityManager.flush() 操作可用于在提交事務之前將所有更改寫入數據庫。lush() 并不執行實際的提交。
實體管理器.刷新(平臺);
EntityManager.refresh() 操作用于從數據庫刷新對象的狀態。刷新可用于恢復更改,或者如果您的 JPA 提供程序支持緩存,則可用于刷新過時的緩存數據。有時需要查詢或查找操作刷新結果。
現在我的代碼看起來像這樣:
public List<Platnosc> createDocumentForInvoice(Integer fakturaId) {
AuthUser user = loginMgr.getLoggedUser();
Platnosc plat = Platnosc.builder()
// I don't set field platnoscNr here it is null
.build();
platDao.save(plat);
entityManager.flush();
entityManager.refresh(plat);
return plat;
}
添加回答
舉報
0/150
提交
取消