首頁 Java Java面試題 java高頻率基礎面試題-(八)

java高頻率基礎面試題-(八)

Sep 11, 2020 pm 03:59 PM
java 面試題

java高頻率基礎面試題-(八)

91,什麼是ORM?

(更多相關面試題推薦:java面試題目

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

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

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

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

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

93,Session的save()、update()、merge()、lock()、saveOrUpdate()和persist()方法分別是做什麼的?有什麼區別?
        Hibernate的物件有三種狀態:瞬時態(transient)、持久態(persistent)和遊離態(detached)。

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

        遊離態的實例可以透過呼叫Upupate(date)、OraveUp 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()方法是把一個沒有更改過的脫管狀態的對象變成持久狀態。

94,闡述Session載入實體物件的過程。
        1、Session在呼叫資料庫查詢功能之前,首先會在一級快取中透過實體類型和主鍵進行查找,如果一級快取查找命中且資料狀態合法,則直接回傳;
        2、如果一一等級快取沒有命中​​,接下來Session會在目前NonExists記錄(相當於一個查詢黑名單,如果出現重複的無效查詢可以迅速做出判斷,從而提升效能)中進行查找,如果NonExists中存在同樣的查詢條件,則回傳null;
        3、如果一級快取查詢失敗查詢二級快取,如果二級快取命中直接回傳;
        4、如果先前的查詢都未命中,則發出SQL語句,如果查詢未發現對應記錄則將此查詢加入Session的NonExists中加以記錄,並回傳null;
        5、依據對位設定和SQL語句得到ResultSet,並建立對應的實體物件;
   #   (一級快取)的管理;
        7、如果有對應的攔截器,執行攔截器的onLoad方法;
        8、如果開啟並設定了要使用二級快取,則將資料物件納入二    8、如果開啟並設定了要使用二級快取級快取;
        9、返回資料物件。

95,MyBatis中使用#和$書寫佔位符有什麼區別?
        #將傳入的資料都當成字串,並且會以傳入的資料自動加上引號;

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

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

96,說明MyBatis中命名空間(namespace)的功能。
        在大型專案中,且可能有大量的SQL語句,而這時候為每個SQL語句起一個唯一的識別(ID)就變得不容易了。為了解決這個問題,在MyBatis中,可以為每個映射檔案起一個唯一的命名空間,這樣定義在這個映射檔案中的每個SQL語句就成了定義在這個命名空間中的一個ID。只要我們能夠保證每個命名空間中這個ID是唯一的,即使在不同映射檔案中的語句ID相同,也不會再產生衝突了。

(影片教學推薦:java課程

97、MyBatis中的動態SQL是什麼意思?
        對於一些複雜的查詢,我們可能會指定多個查詢條件,但是這些條件可能存在也可能不存在,如果不使用持久層框架我們可能需要自己拼裝SQL語句,不過MyBatis提供了動態SQL的功能來解決這個問題。 MyBatis中用於實現動態SQL的元素主要有:
- if    - choose / when / otherwise    - trim    - where    - set  #   - foreach

#lt; ;select id="foo" parameterType="Blog" resultType="Blog">        

  select * from t_blog where 1 = 1                    
          and title = #{title}        
                   

          and content = #{content}                            

          and owner = #{owner}          

98,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物件。

99,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需要具有很強的經驗和能力才行。         
        總之,以使用者的需求為已在有限的資源環境中做出維護性、可擴展性良好的軟體架構為好架構,因此架構只有適合才是最好。

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

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

        Mybatis先去快取查詢結果集,如果沒有則查詢資料庫,如果有則從快取取出回傳結果集就不走資料庫。 Mybatis內部儲存快取使用一個HashMap,key為hashCode sqlId Sql語句。 value為從查詢出來映射產生的java物件
        Mybatis的二級快取即查詢快取,而它的作用域是一個mapper的namespace,即在同一個namespace中查詢sql可以從快取中取得資料。二級緩存是可以跨SqlSession的。

相關教學推薦:java入門教學

#

以上是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

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與Python:核心功能 PHP與Python:核心功能 Apr 13, 2025 am 12:16 AM

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

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

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

創造未來:零基礎的 Java 編程 創造未來:零基礎的 Java 編程 Oct 13, 2024 pm 01:32 PM

Java是熱門程式語言,適合初學者和經驗豐富的開發者學習。本教學從基礎概念出發,逐步深入解說進階主題。安裝Java開發工具包後,可透過建立簡單的「Hello,World!」程式來實踐程式設計。理解程式碼後,使用命令提示字元編譯並執行程序,控制台上將輸出「Hello,World!」。學習Java開啟了程式設計之旅,隨著掌握程度加深,可創建更複雜的應用程式。

See all articles