亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

java關于持久層面試題目整理

瀏覽:2日期:2022-09-04 14:30:33

一、什么是ORM?

對象關系映射(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、返回數據對象。

五、MyBatis中使用#和$書寫占位符有什么區別?

#將傳入的數據都當成一個字符串,會對傳入的數據自動加上引號;

$將傳入的數據直接顯示生成在SQL中。

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

內容補充:

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

● JDBC:數據庫鏈接創建、釋放頻繁造成系統資源浪費從而影響系統性能,如果使用數據庫鏈接池可解決此問題。

MyBatis:在SqlMapConfig.xml中配置數據鏈接池,使用連接池管理數據庫鏈接。

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

MyBatis:將Sql語句配置在XXXXmapper.xml文件中與java代碼分離。

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

MyBatis: Mybatis自動將java對象映射至sql語句。

● JDBC:對結果集解析麻煩,sql變化導致解析代碼變化,且解析前需要遍歷,如果能將數據庫記錄封裝成pojo對象解析比較方便。

MyBatis:Mybatis自動將sql執行結果映射至java對象。

到此這篇關于java關于持久層面試題目整理的文章就介紹到這了,更多相關java持久層面試題目內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 97色老99久久九九爱精品 | 艾小青亚洲专区在线播放 | 人与牲动交bbbbxxxx | 91尤物国产尤物福利在线 | 精品在线不卡 | 97国产在线视频 | 中文字幕在亚洲第一在线 | 黄色aaa毛片 | 婷婷国产天堂久久综合五月 | a黄色| 欧美成人免费大片888 | 久久久四虎成人永久免费网站 | avtt加勒比手机版天堂网 | 丰满寡妇一级毛片 | 亚洲福利视频精选在线视频 | 麻豆视频在线免费观看 | 高清在线精品一区二区 | 96精品国产高清在线看入口 | 亚洲综合福利 | 99色吧| 自偷自拍三级全三级视频 | 免费高清成人啪啪网站 | 黄色xxxxxx | 闲人综合网 | 亚洲精品综合一区在线 | 在线视频一二三区 | 亚洲精品成人一区二区aⅴ 亚洲精品大片 | 91青草久久久久久清纯 | 国产精品无码久久久久 | 精品三级三级三级三级三级 | 国产限制路线1线路2线路3 | 97国产精品欧美一区二区三区 | 亚洲精品视频区 | 黄网站免费看 | 日韩精品第一 | 国产三级在线观看播放 | 亚洲国产色婷婷精品综合在线观看 | 免费视频亚洲 | 欧美精品一区二区三区在线播放 | 黄色一及片 | 无遮挡1000部拍拍拍免费 |