Spring-data-JPA使用時(shí)碰到的問(wèn)題以及解決方案
Spring-data-JPA使用時(shí)碰到的問(wèn)題
本文主要描述我自己在項(xiàng)目使用中碰到的一個(gè)數(shù)據(jù)持久化的問(wèn)題,JPA的一些基礎(chǔ)知識(shí)就不在贅述。
問(wèn)題場(chǎng)景
@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ù)庫(kù)表table_aaa 和 table_bbb是多對(duì)一關(guān)系,級(jí)聯(lián)類型為.ALL:
在service層中按如下的使用就會(huì)有問(wèn)題(一個(gè)事務(wù)中):
{ ....... AaaActivity aaActivity = tableAaaRepository.findBytableAaaId(id); BbbActivity bbbActivity = new BbbActivity (); bbbActivity.setId(123); aaActivity.setBbbActivity(bbbActivity); tableBbbRepository.findBytableBbbId(id); ...... }
兩次查詢之間會(huì)進(jìn)行EntityManage會(huì)進(jìn)行數(shù)據(jù)庫(kù)更新操作,但事務(wù)沒有提交;由于表Aaatable的設(shè)置,會(huì)級(jí)聯(lián)操作Bbbtable表,對(duì)于new 的對(duì)象,此刻默認(rèn)進(jìn)行的是persist()操作,把對(duì)象由瞬時(shí)態(tài)(Transient)——>持久態(tài)(Persistent),但由于bbbActivity設(shè)置的id字段,就會(huì)報(bào)錯(cuò):
org.hibernate.PersistentObjectException: detached entity passed to persist:
解決方式
1、取消id設(shè)置;(persist操作不能設(shè)置對(duì)象id)
2、不新建對(duì)象:
BbbActivity bbbActivity = aaActivity.getBbbActivity ();
然后在此設(shè)置,那么后面的更新,則會(huì)采用merge()的方式;(merge操作:id如果查詢不到則執(zhí)行插入,有則執(zhí)行更新)
補(bǔ)充:在另一個(gè)項(xiàng)目中有遇到了新JPA相關(guān)的問(wèn)題,就此做一些補(bǔ)充;
1、JPA中實(shí)體類之間的對(duì)應(yīng)關(guān)系,與與數(shù)據(jù)庫(kù)中關(guān)聯(lián)表存儲(chǔ)的數(shù)據(jù)相一致:比如oneTomany寫成oneToone,這在實(shí)際映射中數(shù)據(jù)查找時(shí)就會(huì)出問(wèn)題(manyToone 與oneToone不會(huì)參生影響);
2、單向關(guān)聯(lián)和雙向關(guān)聯(lián)的使用要根據(jù)業(yè)務(wù)情況而定;對(duì)于雙向關(guān)聯(lián)在設(shè)置級(jí)聯(lián)操作時(shí),一般設(shè)置在主表中(被關(guān)聯(lián)的表),在從表中設(shè)置關(guān)聯(lián)查詢即可(包含外鍵的表),因?yàn)榘凑_壿媮?lái)說(shuō),從表應(yīng)該是依賴主表而存在的,所以只有當(dāng)主表生成有效信息后,從表才能去管關(guān)聯(lián)插入,而不應(yīng)反過(guò)來(lái)設(shè)置。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring security獲取用戶信息為null或者串值的解決
這篇文章主要介紹了spring security獲取用戶信息為null或者串值的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件(最新推薦)
這篇文章主要介紹了IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01Filter中獲取傳遞參數(shù)方式(解決post請(qǐng)求參數(shù)問(wèn)題)
這篇文章主要介紹了Filter中獲取傳遞參數(shù)方式(解決post請(qǐng)求參數(shù)問(wèn)題),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08Spring如何使用三級(jí)緩存解決循環(huán)依賴
在Spring框架中,循環(huán)依賴是指兩個(gè)或多個(gè)Bean相互依賴,形成閉環(huán),導(dǎo)致無(wú)法完成初始化,此問(wèn)題僅存在于單例Bean中,而原型Bean會(huì)拋出異常,Spring通過(guò)三級(jí)緩存及提前暴露策略解決循環(huán)依賴:一級(jí)緩存存放完全初始化的Bean2024-11-11Mybatis分頁(yè)插件PageHelper配置及使用方法詳解
這篇文章主要介紹了Mybatis分頁(yè)插件PageHelper配置及使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08