Hibernate ORM 或 Hibernate 是用于 java 開發(fā)的免費、開源、對象關(guān)系映射工具(或 ORM 工具)。 它提供了一個將面向?qū)ο竽P陀成涞疥P(guān)系數(shù)據(jù)庫的框架。Hibernate 允許開發(fā)人員構(gòu)造 Java 對象,然后定義這些對象之間的關(guān)系。 然后它將這些對象轉(zhuǎn)換為數(shù)據(jù)庫模式,并最終轉(zhuǎn)換為 SQL 查詢。 生成的 SQL 查詢是底層數(shù)據(jù)庫的原生查詢。
為什么 Java Hibernate 如此受歡迎?Java Hibernate ORM 被如此廣泛采用有四個主要原因:
1、接口不兼容的數(shù)據(jù)庫 - 在紙面上,對象關(guān)系映射是一個非常好的主意。它有助于解決連接其他不兼容數(shù)據(jù)庫的內(nèi)在問題。 Java Hibernate 作為一種 ORM 工具,有助于彌合不兼容數(shù)據(jù)庫之間的差距。
2、自動 SQL 查詢生成 - 人們普遍認(rèn)為開發(fā)人員不需要了解如何編寫 SQL 查詢。因為 Hibernate 自動化了 SQL 查詢編寫過程,它有助于分離開發(fā)人員和數(shù)據(jù)庫管理員的角色。
3、幫助應(yīng)用程序保持與持久性引擎無關(guān) - 務(wù)實地說,應(yīng)用程序應(yīng)該與持久性引擎無關(guān)。 使用哪個數(shù)據(jù)庫并不重要——Hibernate 提供了一種方法來適應(yīng)它。
4、SQL Injection Resistant - Hibernate 為 SQL 查詢提供了一種更安全的替代方案——ORM 限制了 SQL 注入的風(fēng)險。
對 Java Hibernate 性能問題進(jìn)行故障排除
Hibernate 通常是有問題的,并且傾向于生成低效的查詢和非標(biāo)準(zhǔn)的數(shù)據(jù)關(guān)系。這兩個問題可能會導(dǎo)致各種其他性能問題,我們將在下面詳細(xì)說明。
非標(biāo)準(zhǔn)數(shù)據(jù)關(guān)系
Hibernate為了關(guān)聯(lián)兩組數(shù)據(jù),創(chuàng)建了一個外鍵關(guān)系表。對這些數(shù)據(jù)集的最終請求通常會變得不必要地復(fù)雜。為了提高這些非標(biāo)準(zhǔn)數(shù)據(jù)關(guān)系及其查詢的性能,開發(fā)人員可能必須在考慮到特定數(shù)據(jù)庫的情況下編寫變通方案——這可能會首先破壞使用 Hibernate 的全部意義。也許最重要的是,通過依賴開發(fā)人員來簡化或更改這些操作,然后要求開發(fā)人員更好地處理留給數(shù)據(jù)庫管理員或數(shù)據(jù)科學(xué)家的問題。
低效查詢
在查詢方面,Hibernate 可能很笨拙。 它可以在各種情況下創(chuàng)建低效和過多的查詢——通常是默認(rèn)情況下。例如,開發(fā)人員可能會在大學(xué)數(shù)據(jù)庫中編寫一個查詢,允許用戶查看學(xué)生是否注冊了特定課程。 理想的查詢將只查看與該學(xué)生的課程相關(guān)的課程,但 Hibernate 可能會選擇查詢完整的班級表數(shù)據(jù),而不是只查詢適用的數(shù)據(jù)。與僅訪問必要數(shù)據(jù)的查詢相比,此查詢?yōu)榇笮蛿?shù)據(jù)集提供了更長的請求時間。
想了解更多相關(guān)資訊請關(guān)注java培訓(xùn)頻道-查看更多,了解相關(guān)專業(yè)課程信息您可在線咨詢也可免費申請試課。關(guān)注賦能網(wǎng)了解更多:4008-569-579
本文鏈接:
本文章“Java培訓(xùn)了解下什么是Hibernate”已幫助 64 人
免責(zé)聲明:本信息由用戶發(fā)布,本站不承擔(dān)本信息引起的任何交易及知識產(chǎn)權(quán)侵權(quán)的法律責(zé)任!
本文由賦能網(wǎng) 整理發(fā)布。了解更多培訓(xùn)機構(gòu)》培訓(xùn)課程》學(xué)習(xí)資訊》課程優(yōu)惠》課程開班》學(xué)校地址等機構(gòu)信息,可以留下您的聯(lián)系方式,讓課程老師跟你詳細(xì)解答:
咨詢熱線:4008-569-579