
Hibernate ORM 或 Hibernate 是用于 Java 開發的免費、開源、對象關系映射工具(或 ORM 工具)。 它提供了一個將面向對象模型映射到關系數據庫的框架。Hibernate 允許開發人員構造 Java 對象,然后定義這些對象之間的關系。 然后它將這些對象轉換為數據庫模式,并最終轉換為 SQL 查詢。 生成的 SQL 查詢是底層數據庫的原生查詢。
為什么 Java Hibernate 如此受歡迎?
Java Hibernate ORM 被如此廣泛采用有四個主要原因:
1、接口不兼容的數據庫 - 在紙面上,對象關系映射是一個非常好的主意。它有助于解決連接其他不兼容數據庫的內在問題。 Java Hibernate 作為一種 ORM 工具,有助于彌合不兼容數據庫之間的差距。
2、自動 SQL 查詢生成 - 人們普遍認為開發人員不需要了解如何編寫 SQL 查詢。因為 Hibernate 自動化了 SQL 查詢編寫過程,它有助于分離開發人員和數據庫管理員的角色。
3、幫助應用程序保持與持久性引擎無關 - 務實地說,應用程序應該與持久性引擎無關。 使用哪個數據庫并不重要——Hibernate 提供了一種方法來適應它。
4、SQL Injection Resistant - Hibernate 為 SQL 查詢提供了一種更安全的替代方案——ORM 限制了 SQL 注入的風險。
對 Java Hibernate 性能問題進行故障排除
Hibernate 通常是有問題的,并且傾向于生成低效的查詢和非標準的數據關系。這兩個問題可能會導致各種其他性能問題,我們將在下面詳細說明。
非標準數據關系
Hibernate為了關聯兩組數據,創建了一個外鍵關系表。對這些數據集的最終請求通常會變得不必要地復雜。為了提高這些非標準數據關系及其查詢的性能,開發人員可能必須在考慮到特定數據庫的情況下編寫變通方案——這可能會首先破壞使用 Hibernate 的全部意義。也許最重要的是,通過依賴開發人員來簡化或更改這些操作,然后要求開發人員更好地處理留給數據庫管理員或數據科學家的問題。
低效查詢
在查詢方面,Hibernate 可能很笨拙。 它可以在各種情況下創建低效和過多的查詢——通常是默認情況下。例如,開發人員可能會在大學數據庫中編寫一個查詢,允許用戶查看學生是否注冊了特定課程。 理想的查詢將只查看與該學生的課程相關的課程,但 Hibernate 可能會選擇查詢完整的班級表數據,而不是只查詢適用的數據。與僅訪問必要數據的查詢相比,此查詢為大型數據集提供了更長的請求時間。 注:尊重原創文章,轉載請注明出處和鏈接 http://www.hebeijilong.cn/news-id-15967.html 違者必究!部分文章來源于網絡由培訓無憂網編輯部人員整理發布,內容真實性請自行核實或聯系我們,了解更多相關資訊請關注java培訓頻道查看更多,了解相關專業課程信息您可在線咨詢也可免費申請試課。關注官方微信了解更多:150 3333 6050