HQL/JPQL/SQL 查詢支援與語法變更
Hibernate 6 在查詢語言方面做出一些語法上的調整,加強與 JPA 標準的一致性並去除不被建議的用法。開發者在升級時需特別注意下列改變:
UPDATE 查詢中的 FROM 子句: Hibernate 5 的 HQL 更新語句中允許可選的 FROM 關鍵字(例如 update from MyEntity e set e.attr = ...);在 Hibernate 6 中,更新語句不再允許出現 from,語法必須簡化為 update MyEntity e set ...
github.com
。
欄位名稱使用限制: Hibernate 5 的 HQL 查詢中可以直接使用資料庫欄位名稱(非正式但在某些情況可運作),Hibernate 6 則嚴格僅接受實體屬性名稱。也就是說,在 HQL/JPQL 中必須使用 Java 實體的屬性名稱(對應 Java 欄位或 getter),如果誤用資料庫欄名將導致查詢解析失敗
github.com
。例如,如果實體屬性 myText 映射到資料庫欄位 MY_TEXT,在 H6 查詢中應使用 myText,不能直接寫 MY_TEXT
github.com
。
實體與識別值比較: 過去 Hibernate 允許直接在查詢中比較實體與主鍵值(例如 where entity = :idParam,會隱式轉換為比較主鍵),或比較關聯屬性與某主鍵(如 where entity.association = :someId)。Hibernate 6 不再允許直接以實體物件與標量比較,也不允許上述隱式主鍵比較
github.com
。開發者必須顯式比較主鍵欄位,例如改為 where e.id = :idParam,或關聯的情況使用 e.association.id = :someId
github.com
。這提升了查詢語意明確性,也符合 JPA 規範對 JPQL 的要求。
聚合函數類型變更: 在原生 SQL 查詢中使用 COUNT() 函數,Hibernate 5 會將結果視為 BigInteger 型別返回,而 Hibernate 6 調整為返回 Long 型別
github.com
。因此,若應用程式有透過 createNativeQuery 執行計數查詢並依賴 BigInteger,升級後需修改結果處理的型別為 Long
github.com
。
集合屬性函式與操作: Hibernate 5 的 HQL 支援對集合屬性使用類似屬性的方法,例如 collection.size, collection.elements, collection.indices 等「偽屬性」。Hibernate 6 移除了對這些偽屬性的支援
github.com
;取而代之,提供了對應的函數語法來操作集合。
github.com
列出了一些對應關係,例如:
myCollection.size 請改用函數 size(myCollection)
github.com
。
myCollection.elements 改為使用 value(myCollection) 取得集合值。
myCollection.indices 改為使用 index(myCollection)(List 型別)或 key(myCollection)(Map 型別)等。
其他如最大索引、最小元素等均有對應函式(如 maxelement(myCollection) 等)
github.com
。
升級時需要將 HQL 中對集合的操作調整為新語法,以避免語法解析錯誤。
HQL 其他變更: 正如前述,HQL 的 fetch all properties 語句在 Hibernate 6 已經移除
docs.jboss.org
。若在 Hibernate 5 查詢中使用了 fetch all properties 來一次抓取實體所有延遲載入屬性,Hibernate 6 會拋出語法錯誤。替代方式可以利用 JPA 的 EntityGraph 或 Hibernate 特定的載入圖(load graph)功能來達成類似結果
docs.jboss.org
。另外,Hibernate 6 對 HQL 的解析更加嚴謹,如上所述一些寬鬆語法都不再支援;開發者在升級後若遇到查詢解析例外,需要對照官方變更指南修正查詢語句
github.com
github.com
。
上述變更主要針對 Hibernate 查詢語言與 JPQL 的一致性與嚴謹性做優化。在升級過程中,建議全面測試應用中的查詢,確保所有 HQL/JPQL 語句符合新版的語法要求,特別是關注先前可能依賴非標準用法的部分。
相容性問題與升級注意事項
由於 Hibernate 6 帶來多處不相容改動,將現有專案從 Hibernate 5 升級需要仔細規劃。以下列出主要的相容性問題與升級時的注意事項:
Java 和 Jakarta 升級: 如前所述,Hibernate 6 需要 Java 11 以上執行環境
docs.jboss.org
(同時 Spring Boot 3 將要求 Java 17
dzone.com
)。確保開發與部署環境滿足此要求後,必須將專案的 JPA 相依從 javax.persistence 換成 jakarta.persistence。這包括:更新所有實體類別與 DAO 程式碼中的 import、替換註解類別(如 javax.persistence.Entity -> jakarta.persistence.Entity)、調整 persistence.xml 及 orm.xml 的命名空間為 Jakarta
docs.jboss.org
。若應用有使用 JPA 提供者特定的 query hints(查詢提示),其鍵值字串也需改為 "jakarta.persistence.*" 前綴
github.com
。
移除或更改的 API 用法: 升級後,所有使用舊 Hibernate Criteria API (org.hibernate.Criteria 等) 的程式碼將無法運行,必須事先改寫為 JPA Criteria 或 HQL
github.com
github.com
。同樣地,檢查專案中有無使用 Query#iterate()、NativeQuery 呼叫 stored procedure、ResultTransformer 等 Hibernate 5 特有功能——這些在 Hibernate 6 中已經不存在或需要改用新方式
docs.jboss.org
docs.jboss.org
。例如,若有透過 @NamedNativeQuery(callable=true) 定義儲存程序查詢,需要改為使用 @NamedStoredProcedureQuery
docs.jboss.org
。升級時最好先搜尋程式碼中所有 org.hibernate.* 相依的用法,對照 Hibernate 6 的變更清單進行修改。
HQL/JPQL 語法相容性: 在升級環境重新執行應用時,任何不再受支援的查詢語法都會在應用啟動或運行查詢時拋出錯誤。例如,舊程式碼若有 update ... from ...、直接使用資料庫欄名、entity = :id 比較等,需要按照前述新語法進行調整
github.com
github.com
。因此,建議在升級前對所有 HQL/JPQL 做靜態檢查或在升級後加強測試覆蓋,以捕捉這類問題並修正。
資料庫 Schema 與序列: Hibernate 6 默認改為每個實體使用獨立的序列產生主鍵
docs.jboss.org
。如果您的舊專案使用 GenerationType.AUTO 或 SEQUENCE 但未明確指定序列名稱,Hibernate 5 可能一直使用全域的 hibernate_sequence。升級到 Hibernate 6 後,Hibernate 會預期資料庫中存在以實體名稱加 _seq 命名的序列(或 _SEQ,大小寫依資料庫而定)
docs.jboss.org
thorben-janssen.com
。因此,資料庫需要新增對應序列,否則應用啟動時在進行 ID 生成會報錯找不到序列。您可以透過啟用 Hibernate 自動建表(如 hbm2ddl.auto=create)來生成必要的 DDL 腳本,或手動依照 <entity>_seq 規則建立序列
docs.jboss.org
。另外,Hibernate 6 將序列的預設 allocationSize 從 1 提高到了 50
docs.jboss.org
(遵循 JPA 默認設定)。這表示每個序列每次會撥給 Hibernate 50 個ID值批次,以減少交互次數;但相應地也會造成ID不連續的跳號增大。在升級時如果不希望此行為,可透過在 persistence.xml 設定 hibernate.id.db_structure_naming_strategy 為 legacy 或 single 來維持舊行為
docs.jboss.org
thorben-janssen.com
(例如設定為 single 可恢復為所有實體共用單一序列)。同時,請檢查是否有任何測試或資料載入腳本(如 import.sql)硬編碼了 hibernate_sequence 名稱,這些也需要更新為新序列名稱
docs.jboss.org
。
資料庫方言與支援: Hibernate 6 對部分資料庫的版本相容性有所調整。某些舊版本的資料庫方言在 Hibernate 6 核心中不再受支援,已被移至 hibernate-community-dialects 模組或完全移除
github.com
github.com
。例如,先前有版本區分的 Dialect 類別(如 PostgreSQL91Dialect 等)在 6.x 中標記為過時,Hibernate 6 傾向使用單一 Dialect 類別處理同系列資料庫的不同版本
github.com
。升級時如果 hibernate.dialect 設定值對應的方言類別已移至 community 模組,應新增相依或改用新版內建的對應 Dialect。另外,某些較舊的資料庫版本可能不再相容,例如 Hibernate 6 要求 MySQL 至少 8.0、Oracle 至少 12c 等(視不同發行版政策)
github.com
github.com
。在升級前請查閱官方支援矩陣,確保您的資料庫版本受 Hibernate 6 支援,必要時計劃資料庫升級。
其他相容性考量: 除了上述重點,還有一些細節需要注意。例如,如果您有自定義的 Hibernate UserType/CompositeUserType 或其他類型映射實作,Hibernate 6 的類型系統大幅調整,BasicType 與類型描述符 API 已更改,這將導致舊實作無法直接沿用
discourse.hibernate.org
。需要依照 Hibernate 6 新的 JavaType、JdbcType 架構來修改自定義類型的實作方式
discourse.hibernate.org
。再者,Hibernate 6 移除了 JMX 和 JACC 整合,如果應用透過 JMX 監控 Hibernate 或使用 JACC 權限介面,這部分也需遷移或替換
docs.jboss.org
。總之,在升級前應詳細閱讀 Hibernate 6 官方遷移指南,列出所有影響項目,逐一修改程式碼與配置,以確保升級過程順利。
整合與依賴變更
Hibernate 的升級往往牽涉周邊框架與套件的相容性調整,尤其是與 Spring、生態系 JPA 實現及其他第三方模組的整合。 Spring Boot/Spring 框架: Spring Boot 3.x 開始內建使用 Hibernate 6.x 作為預設 JPA 提供者
dzone.com
。這同時伴隨 Spring 框架升級至 6.x(全面轉向 Jakarta EE 依賴)以及最低 Java 17 的要求
dzone.com
。因此,從 Spring Boot 2(Hibernate 5)升級到 Boot 3(Hibernate 6)時,除了上述 Hibernate 自身的變更,還需注意 Spring 提供的 JPA 支援層。例如,Spring Data JPA 3.x 依據 Jakarta Persistence 以及 Hibernate 6 API 進行了調整。對開發者而言,大部分 Spring Data JPA 的 Repository 介面可以不變,但若有使用自定義的 Hibernate 特定功能,則要確保相容(例如 Spring Data 先前允許使用 @Query 注解撰寫 JPQL,此時JPQL語法需要符合 Hibernate 6 的新規則)。整體來說,升級 Spring Boot 時應同步升級相關的 Spring Data、Spring ORM 套件版本,以獲得對 Hibernate 6 的相容支援。此外,Spring Boot 3 默認依賴 Jakarta API(如 servlet, validation, JPA 等),務必要將原本代碼中的所有 Java EE javax.* 類替換為對應的 Jakarta 類,否則應用將無法啟動
dzone.com
dzone.com
。 JPA 規範與實作: Hibernate 6 基於 JPA 3.0 規範。對開發者來說,除了 Jakarta 套件名稱的改變外,JPA 3.0 本身相對 JPA 2.2 沒有引入破壞性的大改。但因為 JPA 轉移到 Jakarta 名下,一些細節如 Persistence 單元的 XML 命名空間更新為 https://jakarta.ee/xml/ns/persistence,persistence.xml 中的 version 屬性對應 Jakarta Persistence 3.0 等,都需要在升級時更新。Hibernate 6 對 JPA 3 的支援已相當完整,若應用遵循標準 JPA 接口開發,理論上除了套件名稱外無需太多改動。但是值得注意的是,驗證框架(Bean Validation)也從 javax.validation 遷移到 jakarta.validation,以及 JTA 交易管理從 javax.transaction 轉為 jakarta.transaction 等。如果專案使用這些規範,也要一併升級對應的 Jakarta 版本,以免產生類別找不到的錯誤。 第三方模組與擴充: 如果專案使用 Hibernate 的擴充模組(如 Hibernate Envers 做審計、Hibernate Search 做全文檢索等),需要確保使用對應支援 Hibernate 6 的版本。多數 Hibernate 附屬專案在 Hibernate 6 發布後也推出了相容更新版本。例如,Envers 在 Hibernate 6 中仍隨核心發行,但 API 可能略有調整;Hibernate Search 則有相容 Jakarta 的新版。類似地,如果有使用 Querydsl 這類第三方查詢DSL框架,也需升級至支援 Hibernate 6 / JPA 3 的版本,因為它們可能涉及底層查詢語法或類型的相容性。在第二級快取方面,常用的 Ehcache、Infinispan 等應與 Hibernate 6 相容,但需升級相依版本以確保與新類型系統協調運作。此外,如前所述,部分資料庫方言被拆分到 hibernate-community-dialects 模組,如果應用使用的資料庫方言不再隨 Hibernate Core 提供,記得在建置中加入相應依賴,否則 Hibernate 可能無法辨識方言類別
github.com
。 架構與設計改進: Hibernate 6 在架構層面做了一些變動,可能影響與自定義擴充的整合:
多資料庫與方言統一: 如前所述,Hibernate 6 將許多資料庫的不同版本支援整合入單一 Dialect 類別中,精簡了方言的繼承體系
github.com
。對應地,如果應用或第三方庫曾直接參考某特定版本的 Dialect(例如 Oracle10gDialect),可能需要改用新對應的 Dialect 名稱(如 OracleDialect)並在 Hibernate 設定中指定正確的資料庫版本屬性。這種調整提高了多資料庫支援的一致性,但需要注意相容設定的更新。
批次處理與延遲載入: Hibernate 一直支援 JDBC 批次更新以及批次抓取(batching)以提升效能。Hibernate 6 在這方面主要是內部優化,對開發者介面的影響不大。您仍可透過設定參數(如 hibernate.jdbc.batch_size)控制批次操作大小。需要注意的是,如果過往有依賴 Hibernate 5 的特定批次行為(例如批次抓取語意),升級後應驗證 Hibernate 6 的預設行為是否一致。一些用戶回饋顯示 Hibernate 6 對延遲載入多對多集合的批次抓取預設值稍有不同,需要在升級後調整設定以符合預期
dzone.com
。建議檢查應用的 hibernate.properties 或 Spring Boot 設定中與批次、抓取有關的選項,在 Hibernate 6 環境下是否需要更改。
Schema 管理與類型支援: 除了序列命名策略的變更,Hibernate 6 擴充了對原生資料庫類型的支援。許多以往需要自定義類型才能處理的 Java 型別,Hibernate 6 現在開箱即用地支援並對應到適當的資料庫型別。例如集合或陣列類型可以對應為資料庫的陣列型別、enum 可以對應資料庫原生 enum 型別、ZonedDateTime/OffsetDateTime 等會映射為帶時區的時間戳等
github.com
github.com
。如果先前專案為了這些型別編寫了自定義 UserType,升級後可能不再需要,或需要調整以利用框架提供的內建支援。同時,Hibernate 6 引入了對 JSON 資料的更好支援,可以更簡便地將 JSON 文本映射到屬性(在特定支援 JSON 的資料庫上)——這些改進意味著整合第三方 JSON 處理庫(或過去的自定實現)時要評估是否繼續需要抑或改用 Hibernate 原生功能。
總而言之,Hibernate ORM 6 在保留與加強現有功能的同時,做出了重大調整和改進。升級時需要關注語法和API的不相容變化,調整專案配置與相依套件版本,以充分利用 Hibernate 6 的新功能(如更佳的效能與現代特性)同時保持系統穩定
dzone.com
。透過上述各方面的比較與指引,希望能協助您順利從 Hibernate 5 過渡到 Hibernate 6。每個應用的情況可能不盡相同,建議在實際升級前詳閱官方文件與社群經驗,以擬定最適合的升級路徑。最後,完整的變更清單和遷移細節可參考官方提供的[Hibernate 6 遷移指南]
infoq.com
和相關資源,以確保沒有遺漏任何重要步驟。
HQL/JPQL/SQL 查詢支援與語法變更

Hibernate 6 在查詢語言方面做出一些語法上的調整，加強與 JPA 標準的一致性並去除不被建議的用法。開發者在升級時需特別注意下列改變：

UPDATE 查詢中的 FROM 子句： Hibernate 5 的 HQL 更新語句中允許可選的 FROM 關鍵字（例如 update from MyEntity e set e.attr = ...）；在 Hibernate 6 中，更新語句不再允許出現 from，語法必須簡化為 update MyEntity e set ...

github.com

。

欄位名稱使用限制： Hibernate 5 的 HQL 查詢中可以直接使用資料庫欄位名稱（非正式但在某些情況可運作），Hibernate 6 則嚴格僅接受實體屬性名稱。也就是說，在 HQL/JPQL 中必須使用 Java 實體的屬性名稱（對應 Java 欄位或 getter），如果誤用資料庫欄名將導致查詢解析失敗

github.com

。例如，如果實體屬性 myText 映射到資料庫欄位 MY_TEXT，在 H6 查詢中應使用 myText，不能直接寫 MY_TEXT

github.com

。

實體與識別值比較： 過去 Hibernate 允許直接在查詢中比較實體與主鍵值（例如 where entity = :idParam，會隱式轉換為比較主鍵），或比較關聯屬性與某主鍵（如 where entity.association = :someId）。Hibernate 6 不再允許直接以實體物件與標量比較，也不允許上述隱式主鍵比較

github.com

。開發者必須顯式比較主鍵欄位，例如改為 where e.id = :idParam，或關聯的情況使用 e.association.id = :someId

github.com

。這提升了查詢語意明確性，也符合 JPA 規範對 JPQL 的要求。

聚合函數類型變更： 在原生 SQL 查詢中使用 COUNT() 函數，Hibernate 5 會將結果視為 BigInteger 型別返回，而 Hibernate 6 調整為返回 Long 型別

github.com

。因此，若應用程式有透過 createNativeQuery 執行計數查詢並依賴 BigInteger，升級後需修改結果處理的型別為 Long

github.com

。

集合屬性函式與操作： Hibernate 5 的 HQL 支援對集合屬性使用類似屬性的方法，例如 collection.size, collection.elements, collection.indices 等「偽屬性」。Hibernate 6 移除了對這些偽屬性的支援

github.com

；取而代之，提供了對應的函數語法來操作集合。

github.com

列出了一些對應關係，例如：

myCollection.size 請改用函數 size(myCollection)

github.com

。

myCollection.elements 改為使用 value(myCollection) 取得集合值。

myCollection.indices 改為使用 index(myCollection)（List 型別）或 key(myCollection)（Map 型別）等。

其他如最大索引、最小元素等均有對應函式（如 maxelement(myCollection) 等)

github.com

。

升級時需要將 HQL 中對集合的操作調整為新語法，以避免語法解析錯誤。

HQL 其他變更： 正如前述，HQL 的 fetch all properties 語句在 Hibernate 6 已經移除

docs.jboss.org

。若在 Hibernate 5 查詢中使用了 fetch all properties 來一次抓取實體所有延遲載入屬性，Hibernate 6 會拋出語法錯誤。替代方式可以利用 JPA 的 EntityGraph 或 Hibernate 特定的載入圖（load graph）功能來達成類似結果

docs.jboss.org

。另外，Hibernate 6 對 HQL 的解析更加嚴謹，如上所述一些寬鬆語法都不再支援；開發者在升級後若遇到查詢解析例外，需要對照官方變更指南修正查詢語句

github.com

github.com

。

上述變更主要針對 Hibernate 查詢語言與 JPQL 的一致性與嚴謹性做優化。在升級過程中，建議全面測試應用中的查詢，確保所有 HQL/JPQL 語句符合新版的語法要求，特別是關注先前可能依賴非標準用法的部分。

相容性問題與升級注意事項

由於 Hibernate 6 帶來多處不相容改動，將現有專案從 Hibernate 5 升級需要仔細規劃。以下列出主要的相容性問題與升級時的注意事項：

Java 和 Jakarta 升級： 如前所述，Hibernate 6 需要 Java 11 以上執行環境

docs.jboss.org

（同時 Spring Boot 3 將要求 Java 17

dzone.com

）。確保開發與部署環境滿足此要求後，必須將專案的 JPA 相依從 javax.persistence 換成 jakarta.persistence。這包括：更新所有實體類別與 DAO 程式碼中的 import、替換註解類別（如 javax.persistence.Entity -> jakarta.persistence.Entity）、調整 persistence.xml 及 orm.xml 的命名空間為 Jakarta

docs.jboss.org

。若應用有使用 JPA 提供者特定的 query hints（查詢提示），其鍵值字串也需改為 "jakarta.persistence.*" 前綴

github.com

。

移除或更改的 API 用法： 升級後，所有使用舊 Hibernate Criteria API (org.hibernate.Criteria 等) 的程式碼將無法運行，必須事先改寫為 JPA Criteria 或 HQL

github.com

github.com

。同樣地，檢查專案中有無使用 Query#iterate()、NativeQuery 呼叫 stored procedure、ResultTransformer 等 Hibernate 5 特有功能——這些在 Hibernate 6 中已經不存在或需要改用新方式

docs.jboss.org

docs.jboss.org

。例如，若有透過 @NamedNativeQuery(callable=true) 定義儲存程序查詢，需要改為使用 @NamedStoredProcedureQuery

docs.jboss.org

。升級時最好先搜尋程式碼中所有 org.hibernate.* 相依的用法，對照 Hibernate 6 的變更清單進行修改。

HQL/JPQL 語法相容性： 在升級環境重新執行應用時，任何不再受支援的查詢語法都會在應用啟動或運行查詢時拋出錯誤。例如，舊程式碼若有 update ... from ...、直接使用資料庫欄名、entity = :id 比較等，需要按照前述新語法進行調整

github.com

github.com

。因此，建議在升級前對所有 HQL/JPQL 做靜態檢查或在升級後加強測試覆蓋，以捕捉這類問題並修正。

資料庫 Schema 與序列： Hibernate 6 默認改為每個實體使用獨立的序列產生主鍵

docs.jboss.org

。如果您的舊專案使用 GenerationType.AUTO 或 SEQUENCE 但未明確指定序列名稱，Hibernate 5 可能一直使用全域的 hibernate_sequence。升級到 Hibernate 6 後，Hibernate 會預期資料庫中存在以實體名稱加 _seq 命名的序列（或 _SEQ，大小寫依資料庫而定）

docs.jboss.org

thorben-janssen.com

。因此，資料庫需要新增對應序列，否則應用啟動時在進行 ID 生成會報錯找不到序列。您可以透過啟用 Hibernate 自動建表（如 hbm2ddl.auto=create）來生成必要的 DDL 腳本，或手動依照 <entity>_seq 規則建立序列

docs.jboss.org

。另外，Hibernate 6 將序列的預設 allocationSize 從 1 提高到了 50

docs.jboss.org

（遵循 JPA 默認設定）。這表示每個序列每次會撥給 Hibernate 50 個ID值批次，以減少交互次數；但相應地也會造成ID不連續的跳號增大。在升級時如果不希望此行為，可透過在 persistence.xml 設定 hibernate.id.db_structure_naming_strategy 為 legacy 或 single 來維持舊行為

docs.jboss.org

thorben-janssen.com

（例如設定為 single 可恢復為所有實體共用單一序列）。同時，請檢查是否有任何測試或資料載入腳本（如 import.sql）硬編碼了 hibernate_sequence 名稱，這些也需要更新為新序列名稱

docs.jboss.org

。

資料庫方言與支援： Hibernate 6 對部分資料庫的版本相容性有所調整。某些舊版本的資料庫方言在 Hibernate 6 核心中不再受支援，已被移至 hibernate-community-dialects 模組或完全移除

github.com

github.com

。例如，先前有版本區分的 Dialect 類別（如 PostgreSQL91Dialect 等）在 6.x 中標記為過時，Hibernate 6 傾向使用單一 Dialect 類別處理同系列資料庫的不同版本

github.com

。升級時如果 hibernate.dialect 設定值對應的方言類別已移至 community 模組，應新增相依或改用新版內建的對應 Dialect。另外，某些較舊的資料庫版本可能不再相容，例如 Hibernate 6 要求 MySQL 至少 8.0、Oracle 至少 12c 等（視不同發行版政策）

github.com

github.com

。在升級前請查閱官方支援矩陣，確保您的資料庫版本受 Hibernate 6 支援，必要時計劃資料庫升級。

其他相容性考量： 除了上述重點，還有一些細節需要注意。例如，如果您有自定義的 Hibernate UserType/CompositeUserType 或其他類型映射實作，Hibernate 6 的類型系統大幅調整，BasicType 與類型描述符 API 已更改，這將導致舊實作無法直接沿用

discourse.hibernate.org

。需要依照 Hibernate 6 新的 JavaType、JdbcType 架構來修改自定義類型的實作方式

discourse.hibernate.org

。再者，Hibernate 6 移除了 JMX 和 JACC 整合，如果應用透過 JMX 監控 Hibernate 或使用 JACC 權限介面，這部分也需遷移或替換

docs.jboss.org

。總之，在升級前應詳細閱讀 Hibernate 6 官方遷移指南，列出所有影響項目，逐一修改程式碼與配置，以確保升級過程順利。

整合與依賴變更

Hibernate 的升級往往牽涉周邊框架與套件的相容性調整，尤其是與 Spring、生態系 JPA 實現及其他第三方模組的整合。 Spring Boot/Spring 框架： Spring Boot 3.x 開始內建使用 Hibernate 6.x 作為預設 JPA 提供者

dzone.com

。這同時伴隨 Spring 框架升級至 6.x（全面轉向 Jakarta EE 依賴）以及最低 Java 17 的要求

dzone.com

。因此，從 Spring Boot 2（Hibernate 5）升級到 Boot 3（Hibernate 6）時，除了上述 Hibernate 自身的變更，還需注意 Spring 提供的 JPA 支援層。例如，Spring Data JPA 3.x 依據 Jakarta Persistence 以及 Hibernate 6 API 進行了調整。對開發者而言，大部分 Spring Data JPA 的 Repository 介面可以不變，但若有使用自定義的 Hibernate 特定功能，則要確保相容（例如 Spring Data 先前允許使用 @Query 注解撰寫 JPQL，此時JPQL語法需要符合 Hibernate 6 的新規則）。整體來說，升級 Spring Boot 時應同步升級相關的 Spring Data、Spring ORM 套件版本，以獲得對 Hibernate 6 的相容支援。此外，Spring Boot 3 默認依賴 Jakarta API（如 servlet, validation, JPA 等），務必要將原本代碼中的所有 Java EE javax.* 類替換為對應的 Jakarta 類，否則應用將無法啟動

dzone.com

dzone.com

。 JPA 規範與實作： Hibernate 6 基於 JPA 3.0 規範。對開發者來說，除了 Jakarta 套件名稱的改變外，JPA 3.0 本身相對 JPA 2.2 沒有引入破壞性的大改。但因為 JPA 轉移到 Jakarta 名下，一些細節如 Persistence 單元的 XML 命名空間更新為 https://jakarta.ee/xml/ns/persistence，persistence.xml 中的 version 屬性對應 Jakarta Persistence 3.0 等，都需要在升級時更新。Hibernate 6 對 JPA 3 的支援已相當完整，若應用遵循標準 JPA 接口開發，理論上除了套件名稱外無需太多改動。但是值得注意的是，驗證框架（Bean Validation）也從 javax.validation 遷移到 jakarta.validation，以及 JTA 交易管理從 javax.transaction 轉為 jakarta.transaction 等。如果專案使用這些規範，也要一併升級對應的 Jakarta 版本，以免產生類別找不到的錯誤。 第三方模組與擴充： 如果專案使用 Hibernate 的擴充模組（如 Hibernate Envers 做審計、Hibernate Search 做全文檢索等），需要確保使用對應支援 Hibernate 6 的版本。多數 Hibernate 附屬專案在 Hibernate 6 發布後也推出了相容更新版本。例如，Envers 在 Hibernate 6 中仍隨核心發行，但 API 可能略有調整；Hibernate Search 則有相容 Jakarta 的新版。類似地，如果有使用 Querydsl 這類第三方查詢DSL框架，也需升級至支援 Hibernate 6 / JPA 3 的版本，因為它們可能涉及底層查詢語法或類型的相容性。在第二級快取方面，常用的 Ehcache、Infinispan 等應與 Hibernate 6 相容，但需升級相依版本以確保與新類型系統協調運作。此外，如前所述，部分資料庫方言被拆分到 hibernate-community-dialects 模組，如果應用使用的資料庫方言不再隨 Hibernate Core 提供，記得在建置中加入相應依賴，否則 Hibernate 可能無法辨識方言類別

github.com

。 架構與設計改進： Hibernate 6 在架構層面做了一些變動，可能影響與自定義擴充的整合：

多資料庫與方言統一： 如前所述，Hibernate 6 將許多資料庫的不同版本支援整合入單一 Dialect 類別中，精簡了方言的繼承體系

github.com

。對應地，如果應用或第三方庫曾直接參考某特定版本的 Dialect（例如 Oracle10gDialect），可能需要改用新對應的 Dialect 名稱（如 OracleDialect）並在 Hibernate 設定中指定正確的資料庫版本屬性。這種調整提高了多資料庫支援的一致性，但需要注意相容設定的更新。

批次處理與延遲載入： Hibernate 一直支援 JDBC 批次更新以及批次抓取(batching)以提升效能。Hibernate 6 在這方面主要是內部優化，對開發者介面的影響不大。您仍可透過設定參數（如 hibernate.jdbc.batch_size）控制批次操作大小。需要注意的是，如果過往有依賴 Hibernate 5 的特定批次行為（例如批次抓取語意），升級後應驗證 Hibernate 6 的預設行為是否一致。一些用戶回饋顯示 Hibernate 6 對延遲載入多對多集合的批次抓取預設值稍有不同，需要在升級後調整設定以符合預期

dzone.com

。建議檢查應用的 hibernate.properties 或 Spring Boot 設定中與批次、抓取有關的選項，在 Hibernate 6 環境下是否需要更改。

Schema 管理與類型支援： 除了序列命名策略的變更，Hibernate 6 擴充了對原生資料庫類型的支援。許多以往需要自定義類型才能處理的 Java 型別，Hibernate 6 現在開箱即用地支援並對應到適當的資料庫型別。例如集合或陣列類型可以對應為資料庫的陣列型別、enum 可以對應資料庫原生 enum 型別、ZonedDateTime/OffsetDateTime 等會映射為帶時區的時間戳等

github.com

github.com

。如果先前專案為了這些型別編寫了自定義 UserType，升級後可能不再需要，或需要調整以利用框架提供的內建支援。同時，Hibernate 6 引入了對 JSON 資料的更好支援，可以更簡便地將 JSON 文本映射到屬性（在特定支援 JSON 的資料庫上）——這些改進意味著整合第三方 JSON 處理庫（或過去的自定實現）時要評估是否繼續需要抑或改用 Hibernate 原生功能。

總而言之，Hibernate ORM 6 在保留與加強現有功能的同時，做出了重大調整和改進。升級時需要關注語法和API的不相容變化，調整專案配置與相依套件版本，以充分利用 Hibernate 6 的新功能（如更佳的效能與現代特性）同時保持系統穩定

dzone.com

。透過上述各方面的比較與指引，希望能協助您順利從 Hibernate 5 過渡到 Hibernate 6。每個應用的情況可能不盡相同，建議在實際升級前詳閱官方文件與社群經驗，以擬定最適合的升級路徑。最後，完整的變更清單和遷移細節可參考官方提供的[Hibernate 6 遷移指南]

infoq.com

和相關資源，以確保沒有遺漏任何重要步驟。
