Spring-data-JPA使用時碰到的問題以及解決方案
Spring-data-JPA使用時碰到的問題
本文主要描述我自己在項目使用中碰到的一個數(shù)據(jù)持久化的問題,JPA的一些基礎(chǔ)知識就不在贅述。
問題場景
@Entity @Table(name = "table_aaa") public class AaaActivity implements Serializable { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "tableA_id", nullable = false, length = 11) private Integer tableId; @ManyToOne(cascade = CascadeType.ALL) @JoinColumn(name = "tableB_id") private BbbActivity bbbActivity ; ...... set And get 方法 }
數(shù)據(jù)庫表table_aaa 和 table_bbb是多對一關(guān)系,級聯(lián)類型為.ALL:
在service層中按如下的使用就會有問題(一個事務(wù)中):
{ ....... AaaActivity aaActivity = tableAaaRepository.findBytableAaaId(id); BbbActivity bbbActivity = new BbbActivity (); bbbActivity.setId(123); aaActivity.setBbbActivity(bbbActivity); tableBbbRepository.findBytableBbbId(id); ...... }
兩次查詢之間會進行EntityManage會進行數(shù)據(jù)庫更新操作,但事務(wù)沒有提交;由于表Aaatable的設(shè)置,會級聯(lián)操作Bbbtable表,對于new 的對象,此刻默認進行的是persist()操作,把對象由瞬時態(tài)(Transient)——>持久態(tài)(Persistent),但由于bbbActivity設(shè)置的id字段,就會報錯:
org.hibernate.PersistentObjectException: detached entity passed to persist:
解決方式
1、取消id設(shè)置;(persist操作不能設(shè)置對象id)
2、不新建對象:
BbbActivity bbbActivity = aaActivity.getBbbActivity ();
然后在此設(shè)置,那么后面的更新,則會采用merge()的方式;(merge操作:id如果查詢不到則執(zhí)行插入,有則執(zhí)行更新)
補充:在另一個項目中有遇到了新JPA相關(guān)的問題,就此做一些補充;
1、JPA中實體類之間的對應(yīng)關(guān)系,與與數(shù)據(jù)庫中關(guān)聯(lián)表存儲的數(shù)據(jù)相一致:比如oneTomany寫成oneToone,這在實際映射中數(shù)據(jù)查找時就會出問題(manyToone 與oneToone不會參生影響);
2、單向關(guān)聯(lián)和雙向關(guān)聯(lián)的使用要根據(jù)業(yè)務(wù)情況而定;對于雙向關(guān)聯(lián)在設(shè)置級聯(lián)操作時,一般設(shè)置在主表中(被關(guān)聯(lián)的表),在從表中設(shè)置關(guān)聯(lián)查詢即可(包含外鍵的表),因為按正常邏輯來說,從表應(yīng)該是依賴主表而存在的,所以只有當(dāng)主表生成有效信息后,從表才能去管關(guān)聯(lián)插入,而不應(yīng)反過來設(shè)置。
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring security獲取用戶信息為null或者串值的解決
這篇文章主要介紹了spring security獲取用戶信息為null或者串值的解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件(最新推薦)
這篇文章主要介紹了IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件,本文結(jié)合實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01Filter中獲取傳遞參數(shù)方式(解決post請求參數(shù)問題)
這篇文章主要介紹了Filter中獲取傳遞參數(shù)方式(解決post請求參數(shù)問題),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08Mybatis分頁插件PageHelper配置及使用方法詳解
這篇文章主要介紹了Mybatis分頁插件PageHelper配置及使用方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-08-08