欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring-data-JPA使用時(shí)碰到的問(wèn)題以及解決方案

 更新時(shí)間:2023年12月27日 08:37:45   作者:huangyaa729  
這篇文章主要介紹了Spring-data-JPA使用時(shí)碰到的問(wèn)題以及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

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)文章

  • 關(guān)于JAVA 數(shù)組的使用介紹

    關(guān)于JAVA 數(shù)組的使用介紹

    本篇文章小編將為大家介紹,關(guān)于JAVA 數(shù)組的使用介紹,有需要的朋友可以參考一下
    2013-04-04
  • spring security獲取用戶信息為null或者串值的解決

    spring security獲取用戶信息為null或者串值的解決

    這篇文章主要介紹了spring security獲取用戶信息為null或者串值的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件(最新推薦)

    IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件(最新推薦)

    這篇文章主要介紹了IntelliJ?IDEA2022.3?springboot?熱部署含靜態(tài)文件,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • 解決Lombok注解不起作用的問(wèn)題

    解決Lombok注解不起作用的問(wèn)題

    這篇文章主要介紹了解決Lombok注解不起作用的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java 集合的Contains和Remove方法

    Java 集合的Contains和Remove方法

    這篇文章主要介紹了Java 集合Contains和Remove方法的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用Java,感興趣的朋友可以了解下
    2021-02-02
  • Filter中獲取傳遞參數(shù)方式(解決post請(qǐng)求參數(shù)問(wèn)題)

    Filter中獲取傳遞參數(shù)方式(解決post請(qǐng)求參數(shù)問(wèn)題)

    這篇文章主要介紹了Filter中獲取傳遞參數(shù)方式(解決post請(qǐng)求參數(shù)問(wèn)題),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Java?超詳細(xì)講解字符流

    Java?超詳細(xì)講解字符流

    字符流就是在字節(jié)流的基礎(chǔ)上,加上編碼,形成的數(shù)據(jù)流,字符流出現(xiàn)的意義是因?yàn)樽止?jié)流在操作字符時(shí),可能會(huì)有中文導(dǎo)致的亂碼,所以由字節(jié)流引申出了字符流
    2022-04-04
  • Spring如何使用三級(jí)緩存解決循環(huán)依賴

    Spring如何使用三級(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í)緩存存放完全初始化的Bean
    2024-11-11
  • JAVA中STRING的常用方法小結(jié)

    JAVA中STRING的常用方法小結(jié)

    這篇文章介紹了JAVA中STRING的常用方法,有需要的朋友可以參考一下
    2013-09-09
  • Mybatis分頁(yè)插件PageHelper配置及使用方法詳解

    Mybatis分頁(yè)插件PageHelper配置及使用方法詳解

    這篇文章主要介紹了Mybatis分頁(yè)插件PageHelper配置及使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08

最新評(píng)論