第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

Hibernate 使用 findOne 和 findById 無法看到數(shù)據(jù)庫中更新后觸發(fā)器對(duì)記錄

Hibernate 使用 findOne 和 findById 無法看到數(shù)據(jù)庫中更新后觸發(fā)器對(duì)記錄

慕后森 2023-10-12 17:25:18
我在我的項(xiàng)目中使用 Spring boot 1.5.22、Spring data 和 Hibernate 5.2.18。當(dāng)我使用 Dao 保存實(shí)體對(duì)象時(shí):platDao.save(plat);數(shù)據(jù)庫中正在執(zhí)行 BEFORE INSERT 類型的觸發(fā)器,該觸發(fā)器正在數(shù)據(jù)庫字段中插入多個(gè)文檔。當(dāng)我在數(shù)據(jù)庫工具中使用 SQL 從數(shù)據(jù)庫中的表中進(jìn)行選擇時(shí),我可以看到該字段中的值。但是當(dāng)我使用 hibernate 和 findOne 方法獲取此記錄時(shí),我在此字段中看到 null:Platnosc plat = platDao.findOne(platId);我也嘗試過這個(gè):Platnosc plat = platDao.findById(platId);但結(jié)果是一樣的,觸發(fā)器設(shè)置的字段為空。我的服務(wù)代碼: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();}回應(yīng)是:“已創(chuàng)建的文檔:信用卡編號(hào)為空,轉(zhuǎn)賬編號(hào)為空,其他付款編號(hào)為空”
查看完整描述

2 回答

?
互換的青春

TA貢獻(xiàn)1797條經(jīng)驗(yàn) 獲得超6個(gè)贊

保存后刷新實(shí)體。


查看完整回答
反對(duì) 回復(fù) 2023-10-12
?
慕俠2389804

TA貢獻(xiàn)1719條經(jīng)驗(yàn) 獲得超6個(gè)贊

為了查看觸發(fā)器所做的更改,我在 platDao.save(plat) 之后在服務(wù)中添加了兩行代碼:

  1. 實(shí)體管理器.flush();

EntityManager.flush() 操作可用于在提交事務(wù)之前將所有更改寫入數(shù)據(jù)庫。lush() 并不執(zhí)行實(shí)際的提交。

  1. 實(shí)體管理器.刷新(平臺(tái));

EntityManager.refresh() 操作用于從數(shù)據(jù)庫刷新對(duì)象的狀態(tài)。刷新可用于恢復(fù)更改,或者如果您的 JPA 提供程序支持緩存,則可用于刷新過時(shí)的緩存數(shù)據(jù)。有時(shí)需要查詢或查找操作刷新結(jié)果。

現(xiàn)在我的代碼看起來像這樣:

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;

}


查看完整回答
反對(duì) 回復(fù) 2023-10-12
  • 2 回答
  • 0 關(guān)注
  • 241 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)