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

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

帶一個自增的Spring JPA復(fù)合PK

帶一個自增的Spring JPA復(fù)合PK

POPMUISE 2022-12-15 16:49:37
我正在嘗試使用 Spring Boot 2.1.2.RELEASE + JPA(使用啟動器)和 MySQL (InnoDB) 來保留具有復(fù)合主鍵的實體,其中一個應(yīng)該自動遞增。我有一個帶有 2 個非抽象子類的抽象類,我正在使用單表策略進(jìn)行繼承。我一直在尋找如何實現(xiàn)這一點,但每一篇似乎都在尋找與我相同的帖子最終都沒有答案(示例)。我當(dāng)前的設(shè)置如下所示(為清楚起見省略了 setter、getter 和構(gòu)造函數(shù))。@Inheritance(strategy = InheritanceType.SINGLE_TABLE)@IdClass(MyEntityPK.class)public abstract class MyEntity {    @Id    @GeneratedValue(strategy = GenerationType.IDENTITY)    long pk1; //Should be auto-incremented    @Id    OffsetDateTime pk2;    //More fields...public class MyEntityPK implements Serializable {   private static final long serialVersionUID = 1L;   long pk1;   OffsetDateTime pk2;}@Repositorypublic interface MyEntityRepository extends CrudRepository<MyEntity, MyEntityPK> {   //Some methods like save().}我發(fā)現(xiàn)的第一個問題是表格生成。如果聲明如下,MySQL 允許創(chuàng)建 PKPRIMARY KEY (pk1, pk2)但不是以不同的順序PRIMARY KEY (pk2, pk1)創(chuàng)建表時,Hibernate 使用第二個,因此失敗。還嘗試更改字段順序但無濟于事。我認(rèn)為這可能是 Hibernate 的問題,但我不確定。任何人都可以確認(rèn)嗎?不管怎樣,我通過手動創(chuàng)建 DDL 腳本并通過 Hibernate 禁用自動 DDL 解決了這個問題。下一個問題,我沒有找到答案,是實體被正確保存在表中,但是存儲庫的保存方法返回的 id 始終為 0。我在保存之前手動設(shè)置 pk2,而保留 pk1由DB完成。entity.setPk2(OffsetDateTime.now());Entity savedEntity = repository.save(entity); //savedEntity has id 1 in table but 0 in code在調(diào)試時,我到達(dá)了這個isNew() 方法。事實證明它返回 false,因為 MyEntityPK 與 null 不同(我設(shè)置了 pk2)。這當(dāng)然不是我所期望的,因為我實際上是在保存一個新實體,因為我的 PK 是復(fù)合的并且我將一個字段留空。所以,我也認(rèn)為這可能是一個錯誤。有一些類覆蓋了 isNew() 方法,但它們似乎沒有被使用。我做錯了什么還是這是一個錯誤?幫助贊賞:)
查看完整描述

1 回答

?
白豬掌柜的

TA貢獻(xiàn)1893條經(jīng)驗 獲得超10個贊

不支持 @EmbededId 或 @IdClass 上的 @GeneratedValue(strategy = GenerationType.IDENTITY)。

這是一個與您的請求完全相關(guān)的錯誤,該錯誤被休眠https://hibernate.atlassian.net/browse/ANN-268拒絕

這是另一個更新的錯誤報告。請注意 Vlad Mihalcea 評論:

這不是一個障礙,它只是一個主要問題。例如,JPA 規(guī)范甚至沒有說明復(fù)合標(biāo)識符中是否允許生成的標(biāo)識符。

無論如何,這僅適用于具有基于序列的標(biāo)識符的 @IdClass,如本文所述。

https://hibernate.atlassian.net/browse/HHH-9662

引文中的文章解釋了如何將 @GeneratedValue(strategy = GenerationType.SEQUENCE) 映射到復(fù)合材料上。


查看完整回答
反對 回復(fù) 2022-12-15
  • 1 回答
  • 0 關(guān)注
  • 101 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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