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

您的位置:首頁技術(shù)文章
文章詳情頁

Java持久層面試題目及答案整理

瀏覽:64日期:2022-09-05 09:32:17

什么是ORM?

對(duì)象關(guān)系映射(Object-Relational Mapping,簡稱ORM)是一種為了解決程序的面向?qū)ο竽P团c數(shù)據(jù)庫的關(guān)系模型互不匹配問題的技術(shù);

簡單的說,ORM是通過使用描述對(duì)象和數(shù)據(jù)庫之間映射的元數(shù)據(jù)(在Java中可以用XML或者是注解),將程序中的對(duì)象自動(dòng)持久化到關(guān)系數(shù)據(jù)庫中或者將關(guān)系數(shù)據(jù)庫表中的行轉(zhuǎn)換成Java對(duì)象,其本質(zhì)上就是將數(shù)據(jù)從一種形式轉(zhuǎn)換到另外一種形式。

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

SessionFactory對(duì)應(yīng)Hibernate的一個(gè)數(shù)據(jù)存儲(chǔ)的概念,它是線程安全的,可以被多個(gè)線程并發(fā)訪問。SessionFactory一般只會(huì)在啟動(dòng)的時(shí)候構(gòu)建。對(duì)于應(yīng)用程序,最好將SessionFactory通過單例模式進(jìn)行封裝以便于訪問。

Session是一個(gè)輕量級(jí)非線程安全的對(duì)象(線程間不能共享session),它表示與數(shù)據(jù)庫進(jìn)行交互的一個(gè)工作單元。Session是由SessionFactory創(chuàng)建的,在任務(wù)完成之后它會(huì)被關(guān)閉。Session是持久層服務(wù)對(duì)外提供的主要接口。

Session會(huì)延遲獲取數(shù)據(jù)庫連接(也就是在需要的時(shí)候才會(huì)獲取)。為了避免創(chuàng)建太多的session,可以使用ThreadLocal將session和當(dāng)前線程綁定在一起,這樣可以讓同一個(gè)線程獲得的總是同一個(gè)session。

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

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

Hibernate的對(duì)象有三種狀態(tài):瞬時(shí)態(tài)(transient)、持久態(tài)(persistent)和游離態(tài)(detached)。

瞬時(shí)態(tài)的實(shí)例可以通過調(diào)用save()、persist()或者saveOrUpdate()方法變成持久態(tài);

游離態(tài)的實(shí)例可以通過調(diào)用 update()、saveOrUpdate()、lock()或者replicate()變成持久態(tài)。save()和persist()將會(huì)引發(fā)SQL的INSERT語句,而update()或merge()會(huì)引發(fā)UPDATE語句。

save()和update()的區(qū)別在于一個(gè)是將瞬時(shí)態(tài)對(duì)象變成持久態(tài),一個(gè)是將游離態(tài)對(duì)象變?yōu)槌志脩B(tài)。merge()方法可以完成save()和update()方法的功能,它的意圖是將新的狀態(tài)合并到已有的持久化對(duì)象上或創(chuàng)建新的持久化對(duì)象。

對(duì)于persist()方法,按照官方文檔的說明:

1、persist()方法把一個(gè)瞬時(shí)態(tài)的實(shí)例持久化,但是并不保證標(biāo)識(shí)符被立刻填入到持久化實(shí)例中,標(biāo)識(shí)符的填入可能被推遲到flush的時(shí)間;

2、persist()方法保證當(dāng)它在一個(gè)事務(wù)外部被調(diào)用的時(shí)候并不觸發(fā)一個(gè)INSERT語句,當(dāng)需要封裝一個(gè)長會(huì)話流程的時(shí)候,persist()方法是很有必要的;

3、save()方法不保證第2條,它要返回標(biāo)識(shí)符,所以它會(huì)立即執(zhí)行INSERT語句,不管是在事務(wù)內(nèi)部還是外部。

至于lock()方法和update()方法的區(qū)別,update()方法是把一個(gè)已經(jīng)更改過的脫管狀態(tài)的對(duì)象變成持久狀態(tài);lock()方法是把一個(gè)沒有更改過的脫管狀態(tài)的對(duì)象變成持久狀態(tài)。

闡述Session加載實(shí)體對(duì)象的過程。

1、Session在調(diào)用數(shù)據(jù)庫查詢功能之前,首先會(huì)在一級(jí)緩存中通過實(shí)體類型和主鍵進(jìn)行查找,如果一級(jí)緩存查找命中且數(shù)據(jù)狀態(tài)合法,則直接返回;

2、如果一級(jí)緩存沒有命中,接下來Session會(huì)在當(dāng)前NonExists記錄(相當(dāng)于一個(gè)查詢黑名單,如果出現(xiàn)重復(fù)的無效查詢可以迅速做出判斷,從而提升性能)中進(jìn)行查找,如果NonExists中存在同樣的查詢條件,則返回null;

3、如果一級(jí)緩存查詢失敗查詢二級(jí)緩存,如果二級(jí)緩存命中直接返回;

4、如果之前的查詢都未命中,則發(fā)出SQL語句,如果查詢未發(fā)現(xiàn)對(duì)應(yīng)記錄則將此次查詢添加到Session的NonExists中加以記錄,并返回null;

5、根據(jù)映射配置和SQL語句得到ResultSet,并創(chuàng)建對(duì)應(yīng)的實(shí)體對(duì)象;

6、將對(duì)象納入Session(一級(jí)緩存)的管理;

7、如果有對(duì)應(yīng)的攔截器,則執(zhí)行攔截器的onLoad方法;

8、如果開啟并設(shè)置了要使用二級(jí)緩存,則將數(shù)據(jù)對(duì)象納入二級(jí)緩存;

9、返回?cái)?shù)據(jù)對(duì)象。

#將傳入的數(shù)據(jù)都當(dāng)成一個(gè)字符串,會(huì)對(duì)傳入的數(shù)據(jù)自動(dòng)加上引號(hào);

$將傳入的數(shù)據(jù)直接顯示生成在SQL中。

注意:使用$占位符可能會(huì)導(dǎo)致SQL注射攻擊,能用#的地方就不要使用$,寫order by子句的時(shí)候應(yīng)該用$而不是#。

解釋一下MyBatis中命名空間(namespace)的作用。

在大型項(xiàng)目中,可能存在大量的SQL語句,這時(shí)候?yàn)槊總€(gè)SQL語句起一個(gè)唯一的標(biāo)識(shí)(ID)就變得并不容易了。

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

只要我們能夠保證每個(gè)命名空間中這個(gè)ID是唯一的,即使在不同映射文件中的語句ID相同,也不會(huì)再產(chǎn)生沖突了。

MyBatis中的動(dòng)態(tài)SQL是什么意思?

對(duì)于一些復(fù)雜的查詢,我們可能會(huì)指定多個(gè)查詢條件,但是這些條件可能存在也可能不存在,如果不使用持久層框架我們可能需要自己拼裝SQL語句,不過MyBatis提供了動(dòng)態(tài)SQL的功能來解決這個(gè)問題。MyBatis中用于實(shí)現(xiàn)動(dòng)態(tài)SQL的元素主要有:

- if - choose / when / otherwise - trim - where - set - foreach

用法舉例:

<select 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:數(shù)據(jù)庫鏈接創(chuàng)建、釋放頻繁造成系統(tǒng)資源浪費(fèi)從而影響系統(tǒng)性能,如果使用數(shù)據(jù)庫鏈接池可解決此問題。

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

2、JDBC:Sql語句寫在代碼中造成代碼不易維護(hù),實(shí)際應(yīng)用sql變化的可能較大,sql變動(dòng)需要改變java代碼。

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

3、JDBC:向sql語句傳參數(shù)麻煩,因?yàn)閟ql語句的where條件不一定,可能多也可能少,占位符需要和參數(shù)一一對(duì)應(yīng)。

MyBatis: Mybatis自動(dòng)將java對(duì)象映射至sql語句。

4,JDBC:對(duì)結(jié)果集解析麻煩,sql變化導(dǎo)致解析代碼變化,且解析前需要遍歷,如果能將數(shù)據(jù)庫記錄封裝成pojo對(duì)象解析比較方便。

MyBatis:Mybatis自動(dòng)將sql執(zhí)行結(jié)果映射至java對(duì)象。

MyBatis與Hibernate有哪些不同?

1、Mybatis和hibernate不同,它不完全是一個(gè)ORM框架,因?yàn)镸yBatis需要程序員自己編寫Sql語句,不過mybatis可以通過XML或注解方式靈活配置要運(yùn)行的sql語句,并將java對(duì)象和sql語句映射生成最終執(zhí)行的sql,最后將sql執(zhí)行的結(jié)果再映射生成java對(duì)象。

2、Mybatis學(xué)習(xí)門檻低,簡單易學(xué),程序員直接編寫原生態(tài)sql,可嚴(yán)格控制sql執(zhí)行性能,靈活度高,非常適合對(duì)關(guān)系數(shù)據(jù)模型要求不高的軟件開發(fā),例如互聯(lián)網(wǎng)軟件、企業(yè)運(yùn)營類軟件等,因?yàn)檫@類軟件需求變化頻繁,一但需求變化要求成果輸出迅速。

但是靈活的前提是mybatis無法做到數(shù)據(jù)庫無關(guān)性,如果需要實(shí)現(xiàn)支持多種數(shù)據(jù)庫的軟件則需要自定義多套sql映射文件,工作量大。

3、Hibernate對(duì)象/關(guān)系映射能力強(qiáng),數(shù)據(jù)庫無關(guān)性好,對(duì)于關(guān)系模型要求高的軟件(例如需求固定的定制化軟件)如果用hibernate開發(fā)可以節(jié)省很多代碼,提高效率。

但是Hibernate的缺點(diǎn)是學(xué)習(xí)門檻高,要精通門檻更高,而且怎么設(shè)計(jì)O/R映射,在性能和對(duì)象模型之間如何權(quán)衡,以及怎樣用好Hibernate需要具有很強(qiáng)的經(jīng)驗(yàn)和能力才行。

總之,按照用戶的需求在有限的資源環(huán)境下只要能做出維護(hù)性、擴(kuò)展性良好的軟件架構(gòu)都是好架構(gòu),所以框架只有適合才是最好。

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

簡單的說一下MyBatis的一級(jí)緩存和二級(jí)緩存?

Mybatis首先去緩存中查詢結(jié)果集,如果沒有則查詢數(shù)據(jù)庫,如果有則從緩存取出返回結(jié)果集就不走數(shù)據(jù)庫。Mybatis內(nèi)部存儲(chǔ)緩存使用一個(gè)HashMap,key為hashCode+sqlId+Sql語句。value為從查詢出來映射生成的java對(duì)象

Mybatis的二級(jí)緩存即查詢緩存,它的作用域是一個(gè)mapper的namespace,即在同一個(gè)namespace中查詢sql可以從緩存中獲取數(shù)據(jù)。二級(jí)緩存是可以跨SqlSession的。

以上就是Java持久層面試題目及答案整理的詳細(xì)內(nèi)容,更多關(guān)于Java持久層面試題目的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 国产一区二区三区久久 | 免费能看的黄色网址 | 韩国19禁主播裸免费福利 | 国产日本欧美亚洲精品视 | 一级黄色片网 | 国产精品视频在 | 点击进入毛片免费观看 | 欧美日韩1区 | 日韩a一级欧美一级 | 亚洲 欧美 在线观看 | 色婷婷激情综合 | 三级成人影院 | 黄色免费毛片 | 在线观看嗯啊成人动作片 | 久久久国产精品免费看 | 制服第一页 | 手机看片国产日韩 | 99久久er热在这里只有精品16 | 国内精品免费视频自在线 | 美女拍拍拍无遮挡 | 成人福利小视频 | 在线 | 一区二区三区 | 亚洲午夜精品久久久久久成年 | 国产精品免费一区二区三区 | 一级h片 | 日本护士69xxxx免费 | 国产视频www| 老司机51精品视频在线观看 | 久久中文字幕综合婷婷 | 国产成人综合亚洲一区 | 国产精品美女一区二区三区 | 亚洲欧美久久久久久久久久爽网站 | 麻豆传媒官网入口 | 香蕉国产一区二区 | 91福利一区二区三区 | 免费观看91视频 | 精品免费久久久久国产一区 | 一级黄色毛片免费看 | 久热香蕉在线爽青青 | 毛片毛片毛片毛片毛片怎么 | 日韩精品欧美国产精品亚 |