首頁 Java Java面試題 Java持久層面試題目

Java持久層面試題目

Dec 10, 2019 pm 02:41 PM
java

Java持久層面試題目

什麼是ORM?                       (建議學習:java訪談題目

#物件關係對應(Object-Relational Mapping,簡稱ORM)是一種為了解決程式的物件導向模型與資料庫關係式的關聯式模型互不匹配問題的技術;

簡單的說,ORM是透過使用描述物件和資料庫之間映射的元資料(在Java中可以用XML或註解),將程式中的物件自動持久化到關聯式資料庫中或將關聯式資料庫表中的行轉換成Java對象,其本質上就是將資料從一種形式轉換到另外一種形式。

Hibernate中SessionFactory是執行緒安全的嗎? Session是線程安全的嗎(兩個線程能夠共享同一個Session嗎)?

SessionFactory對應Hibernate的一個資料儲存的概念,它是執行緒安全的,可以被多個執行緒並發存取。 SessionFactory一般只會在啟動的時候建置。對於應用程序,最好將SessionFactory透過單例模式進行封裝以便於存取。

Session是一個輕量級非執行緒安全的物件(執行緒間不能共享session),它表示與資料庫互動的一個工作單元。 Session是由SessionFactory創建的,在任務完成之後它會關閉。 Session是持久層服務對外提供的主要介面。

Session會延遲取得資料庫連線(也就是在需要的時候才會取得)。為了避免創建太多的session,可以使用ThreadLocal將session和當前線程綁定在一起,這樣可以讓同一個線程獲得的總是同一個session。

Hibernate 3中SessionFactory的getCurrentSession()方法就可以做到。

Session的save()、update()、merge()、lock()、saveOrUpdate()和persist()方法分別是做什麼的?有什麼區別?

Hibernate的物件有三種狀態:瞬時態(transient)、持久態(persistent)和遊離態(detached)。

瞬時態的實例可以透過呼叫save()、persist()或saveOrUpdate()方法變成持久性;

遊離態的實例可以透過呼叫update()、saveOrUpdate()、 lock()或replicate()變成持久態。 save()和persist()將會引發SQL的INSERT語句,而update()或merge()會引發UPDATE語句。

save()和update()的差別在於一個是將瞬時態物件變成持久態,一個是將遊離態物件變成持久態。 merge()方法可以完成save()和update()方法的功能,它的意圖是將新的狀態合併到現有的持久化物件上或建立新的持久化物件。

對於persist()方法,依照官方文件的說明:

#1、persist()方法把一個瞬時態的實例持久化,但並不保證標識符立刻被填入到持久化實例中,標識符的填入可能被推遲到flush的時間;

2、persist()方法保證當它在一個事務外部被調用的時候並不觸發一個INSERT語句,當需要封裝一個長會話流程的時候,persist()方法是很有必要的;

3、save()方法不保證第2條,它要回傳標識符,所以它會立即執行INSERT語句,不管是在事務內部或外部。

至於lock()方法和update()方法的區別,update()方法是把一個已經更改過的脫管狀態的物件變成持久狀態;lock()方法是把一個沒有更改過的脫管狀態的物件變成持久狀態。

闡述Session載入實體物件的過程。

1、Session在呼叫資料庫查詢功能之前,首先會在一級快取中透過實體類型和主鍵進行查找,如果一級快取查找命中且資料狀態合法,則直接返回;

2、如果一級快取沒有命中​​,接下來Session會在目前NonExists記錄(相當於一個查詢黑名單,如果出現重複的無效查詢可以迅速做出判斷,從而提升效能)中進行查找,如果NonExists中存在同樣的查詢條件,則傳回null;

3、如果一級快取查詢失敗查詢二級緩存,如果二級快取命中直接回傳;

4、如果之前的查詢都未命中,則發出SQL語句,如果查詢未發現對應記錄則將此次查詢添加到Session的NonExists中加以記錄,並返回null;

5、根據映射配置和SQL語句得到ResultSet,並建立對應的實體物件;

6、將物件納入Session(一級快取)的管理;

7、如果有對應的攔截器,則執行攔截器的onLoad方法;

8、如果開啟並設定了要使用二級緩存,則將資料物件納入二級緩存;

9、傳回資料物件。

 

#將傳入的資料都當成字串,會對傳入的資料自動加上引號;

$將傳入的資料直接顯示產生在SQL中。

注意:使用$佔位符可能會導致SQL注射攻擊,能用#的地方就不要使用$,寫order by子句的時候應該用$而不是#。

說明MyBatis中命名空間(namespace)的作用。

在大型專案中,可能存在大量的SQL語句,這時候為每個SQL語句起一個唯一的識別(ID)就變得不容易了。

為了解決這個問題,在MyBatis中,可以為每個映射檔案起一個唯一的命名空間,這樣定義在這個映射檔案中的每個SQL語句就成了定義在這個命名空間中的一個ID。

只要我們能夠保證每個命名空間中這個ID是唯一的,即使在不同映射檔案中的語句ID相同,也不會再產生衝突了。

MyBatis中的動態SQL是什麼意思?

對於一些複雜的查詢,我們可能會指定多個查詢條件,但是這些條件可能存在也可能不存在,如果不使用持久層框架我們可能需要自己拼裝SQL語句,不過MyBatis提供了動態SQL的功能來解決這個問題。 MyBatis中用來實作動態SQL的元素主要有:

- if    - choose / when / otherwise    - trim    - where    - set     - foreach
登入後複製

用法範例:

<select id="foo" parameterType="Blog" resultType="Blog">        
select * from t_blog where 1 = 1
<if test="title != null">            
   and title = #{title}
</if>
<if test="content != null">            
   and content = #{content}
</if>
<if test="owner != null">            
   and owner = #{owner}
</if>
</select>
登入後複製

##JDBC程式設計有哪些不足之處,MyBatis是如何解決這些問題的?

1、JDBC:資料庫連結建立、釋放頻繁造成系統資源浪費進而影響系統效能,如果使用資料庫連結池可解決此問題。

MyBatis:在SqlMapConfig.xml中設定資料連結池,使用連接池管理資料庫連結。

2、JDBC:Sql語句寫在程式碼中造成程式碼不易維護,實際應用sql變化的可能較大,sql變動需要改變java程式碼。

MyBatis:將Sql語句配置在XXXXmapper.xml檔案中與java程式碼分開。

3、JDBC:向sql語句傳參數麻煩,因為sql語句的where條件不一定,可能多也可能少,佔位符需要和參數一一對應。

MyBatis: Mybatis自動將java物件對應至sql語句。

4,JDBC:對結果集解析麻煩,sql變化導致解析程式碼變化,解析前需要遍歷,如果能將資料庫記錄封裝成pojo物件解析比較方便。

MyBatis:Mybatis自動將sql執行結果對應至java物件。

MyBatis與Hibernate有哪些不同?

1、Mybatis和hibernate不同,它不完全是一個ORM框架,因為MyBatis需要程式設計師自己寫Sql語句,不過mybatis可以透過XML或註解方式靈活配置要運行的sql語句,並將java物件和sql語句映射產生最終執行的sql,最後將sql執行的結果再映射產生java物件。

2、Mybatis學習門檻低,簡單易學,程式設計師直接編寫原始生態sql,可嚴格控制sql執行效能,靈活度高,非常適合對關聯式資料模型要求不高的軟體開發,例如互聯網軟體、企業營運軟體等,因為這類軟體需求變化頻繁,一但需求變化要求成果輸出迅速。

但是靈活的前提是mybatis無法做到資料庫無關性,如果需要實作支援多種資料庫的軟體則需要自訂多套sql映射文件,工作量大。  

3、Hibernate物件/關係映射能力強,資料庫無關性好,對於關係模型要求高的軟體(例如需求固定的客製化軟體)如果用hibernate開發可以節省很多程式碼,提高效率。

但是Hibernate的缺點是學習門檻高,要精通門檻更高,而且怎麼設計O/R映射,在性能和對像模型之間如何權衡,以及怎樣用好Hibernate需要具有很強的經驗和能力才行。          

總之,依照使用者的需求在有限的資源環境下只要能做出維護性、可擴展性良好的軟體架構就是好架構,所以架構只有適合才是最好。

(這裡也可以結合自己的理解說,別說的收不住)

#簡單的說一下MyBatis的一級快取和二級快取?

Mybatis先到快取中查詢結果集,如果沒有則查詢資料庫,如果有則從快取取出回傳結果集就不走資料庫。 Mybatis內部儲存快取使用一個HashMap,key為hashCode sqlId Sql語句。 value為從查詢出來映射生成的java物件

Mybatis的二級快取即查詢緩存,它的作用域是一個mapper的namespace,即在同一個namespace中查詢sql可以從快取中獲取資料。二級緩存是可以跨SqlSession的。

以上是Java持久層面試題目的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java Spring 面試題 Java Spring 面試題 Aug 30, 2024 pm 04:29 PM

在本文中,我們保留了最常被問到的 Java Spring 面試問題及其詳細答案。這樣你就可以順利通過面試。

突破或從Java 8流返回? 突破或從Java 8流返回? Feb 07, 2025 pm 12:09 PM

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

PHP:網絡開發的關鍵語言 PHP:網絡開發的關鍵語言 Apr 13, 2025 am 12:08 AM

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

Java 中的時間戳至今 Java 中的時間戳至今 Aug 30, 2024 pm 04:28 PM

Java 中的時間戳記到日期指南。這裡我們也結合範例討論了介紹以及如何在java中將時間戳記轉換為日期。

PHP與Python:了解差異 PHP與Python:了解差異 Apr 11, 2025 am 12:15 AM

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

Java程序查找膠囊的體積 Java程序查找膠囊的體積 Feb 07, 2025 am 11:37 AM

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4

PHP與其他語言:比較 PHP與其他語言:比較 Apr 13, 2025 am 12:19 AM

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP與Python:核心功能 PHP與Python:核心功能 Apr 13, 2025 am 12:16 AM

PHP和Python各有優勢,適合不同場景。 1.PHP適用於web開發,提供內置web服務器和豐富函數庫。 2.Python適合數據科學和機器學習,語法簡潔且有強大標準庫。選擇時應根據項目需求決定。

See all articles