黄色网址大全免费-黄色网址你懂得-黄色网址你懂的-黄色网址有那些-免费超爽视频-免费大片黄国产在线观看

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節(jié)點(diǎn)LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 hot資訊 什么是Mybatis

什么是Mybatis

更新時(shí)間:2021-07-16 16:20:09 來源:動力節(jié)點(diǎn) 瀏覽1260次

1.什么是Mybatis?

  • MyBatis是一個(gè)半ORM(對象關(guān)系映射)框架,它內(nèi)部封裝了JDBC,開發(fā)時(shí)只需要關(guān)注SQL語句本身,不需要花費(fèi)精力去加載驅(qū)動、創(chuàng)建連接、創(chuàng)建Statement等繁雜過程。程序員直接編寫原生態(tài)sql,可以嚴(yán)格控制sql執(zhí)行性能,靈活度高。
  • Mybatis可以使用XML或注解來配置和映射原生信息,將POJO映射成數(shù)據(jù)庫中的記錄,避免幾乎所有JDBC代碼和手動設(shè)置參數(shù)以及獲得結(jié)果集。
  • 通過xml文件或注解的方式將要執(zhí)行的各種statement配置起來,并通過java對象和statement中sql的動態(tài)參數(shù)進(jìn)行映射生成最終執(zhí)行的sql語句,最后由Mybatis框架執(zhí)行sql并將返回結(jié)果映射為java對象并返回。(從執(zhí)行sql到返回result的過程)。

2.Mybatis的優(yōu)點(diǎn)

  • 基于SQL語句編程,相當(dāng)靈活,不會對應(yīng)用程序或者數(shù)據(jù)庫的現(xiàn)有設(shè)計(jì)造成任何影響,SQL寫在XML文件中,接觸SQL與程序代碼的耦合,便于統(tǒng)一管理;提供XML便簽,支持編寫動態(tài)SQL語句,并可以重用。
  • 與JDBC相比,減少了50%以上的代碼量,消除了JDBC大量冗余的代碼,不需要手動開關(guān)連接。
  • 很好的與各種數(shù)據(jù)庫兼容(因?yàn)镸yBatis使用JDBC連接數(shù)據(jù),所以只要JDBC支持?jǐn)?shù)據(jù)庫MyBatis都支持)。
  • 能夠與Spring框架很好的集成。
  • 提供映射標(biāo)簽,支持對象與數(shù)據(jù)庫的ORM字段關(guān)系映射;提供對象關(guān)系映射標(biāo)簽,支持對象關(guān)系組件維護(hù)。

3.Mybatis框架的缺點(diǎn)

  • SQL語句的編寫工作量較大,尤其當(dāng)字段多,關(guān)聯(lián)表多時(shí),對開發(fā)人員編寫SQL語句的功底有一定要求。
  • SQL語句依賴數(shù)據(jù)庫,導(dǎo)致數(shù)據(jù)庫移植性差,不能隨意更換數(shù)據(jù)庫。

4.MyBatis框架使用場合

  • MyBatis專注于SQL本身,是一個(gè)足夠靈活的DAO層解決方案。
  • 對性能的要求很高,或者對需求變化較多的項(xiàng)目,如互聯(lián)網(wǎng)項(xiàng)目,MyBatis將是不錯(cuò)的選擇。

5.Mybatis與Hibernate有哪些不同

  • Mybatis不完全是一個(gè)ORM框架,因?yàn)镸ybatis需要程序員自己編寫SQL語句。
  • Mybatis直接編寫原生態(tài)SQL,可以嚴(yán)格控制SQL執(zhí)行性能,靈活度高,非常適合對關(guān)系數(shù)據(jù)模型要求不高的軟件開發(fā),因?yàn)檫@類軟件需求變化頻繁,一旦需求變化要求迅速輸出成果。但是靈活的前提是Mybatis無法做到數(shù)據(jù)庫無關(guān)性,如果需要實(shí)現(xiàn)支持多種數(shù)據(jù)庫的軟件,則需要自定義多套SQL映射文件,工作量大。
  • Hibernate對象/關(guān)系映射能力強(qiáng),數(shù)據(jù)無關(guān)性好,對于關(guān)系模型要求高的軟件,如果用Hibernate開發(fā)可以節(jié)省很多代碼,提高效率。

6.Mybatis是如何進(jìn)行分頁的?分頁插件的原理是什么?

  • MyBatis使用RowBounds對象進(jìn)行分頁,它是針對ResultSet結(jié)果集執(zhí)行的內(nèi)存分頁而非物理分頁。可以在SQL內(nèi)直接書寫帶有物理分頁的參數(shù)來完成分頁功能。也可以使用分頁插件來完成物理分頁。
  • 分頁插件的基本原理是使用Mybatis提供的插件接口,實(shí)現(xiàn)自定義插件,在插件的攔截方法內(nèi)攔截執(zhí)行的SQL,然后重新SQL,根據(jù)dialect方言,添加對應(yīng)的物理分頁語句和物理分頁參數(shù)。

7.Mybatis是如何將SQL執(zhí)行結(jié)果封裝為目標(biāo)對象并返回的?都有哪些映射形式?

  • 第一種是使用標(biāo)簽:逐一定義數(shù)據(jù)庫列明和對象屬性名之間的映射關(guān)系。
  • 第二種是使用SQL列的別名功能:將列的別名書寫為對象屬性名。
  • 有了列名和屬性名的映射關(guān)系后,Mybatis通過反射創(chuàng)建對象,同時(shí)使用反射給對象的屬性逐一賦值并返回,那些找不到映射關(guān)系的屬性是無法賦值的。

8.Mybatis動態(tài)SQL有什么用?執(zhí)行原理?有哪些動態(tài)SQL?

  • Mybatis動態(tài)SQL可以在xml映射文件內(nèi),以標(biāo)簽的形式編寫動態(tài)sql,執(zhí)行原理是根據(jù)表達(dá)式的值完成邏輯判斷并動態(tài)拼接SQL的功能。
  • Mybatis提供了9種動態(tài)SQL標(biāo)簽:trim|where|set|foreach|if|choose|when|otherwise|bind

9.XML映射文件中,除了常見的select|insert|update|delete標(biāo)簽之外,還有哪些標(biāo)簽?

  • 還有很多其他的標(biāo)簽,<resultMap>、<parameterMap>、<sql>、<include>、<selectKey>,加上動態(tài)sql的9個(gè)標(biāo)簽,trim|where|set|foreach|if|choose|when|otherwise|bind等,其中<sql>為sql片段標(biāo)簽,通過<include>標(biāo)簽引入sql片段,<selectKey>為不支持自增的主鍵生成策略標(biāo)簽。

10.Mybatis的XML映射文件中,不同的XML映射文件,id是否可以重復(fù)?

  • 不同的XML映射文件,如果配置了namespace,那么id可以重復(fù);如果沒有配置namespace,那么id不能重復(fù);
  • 原因是namespace+id是作為Map的key使用的,如果沒有namespace,就剩下id,那么,id重復(fù)會導(dǎo)致數(shù)據(jù)互相覆蓋。有了namespace,自然id就可以重復(fù),namespace不同,那么namespace+id自然也就會不同。

11.為什么說Mybatis是半自動ORM映射工具?它與全自動的區(qū)別在哪里?

  • Hibernate屬于全自動的ORM映射工具,使用Hibernate查詢關(guān)聯(lián)對象或者關(guān)聯(lián)集合對象時(shí),可以根據(jù)對象關(guān)系模型直接獲取,所以它是全自動的。而Mybatis在查詢關(guān)聯(lián)對象或關(guān)聯(lián)集合對象時(shí),需要手動編寫SQL來完成,所以稱之為半自動ORM映射工具。

12.Mybatis實(shí)現(xiàn)一對一有幾種方式?具體是怎么操作的?

  • 有聯(lián)合查詢和嵌套查詢,聯(lián)合查詢是幾個(gè)表聯(lián)合查詢,只查詢一次,通過在resultMap里配置association節(jié)點(diǎn)配置一對一的類就可以完成。
  • 嵌套查詢是先查詢一個(gè)表,根據(jù)這個(gè)表里的結(jié)果的外鍵id,再去另一表里查詢數(shù)據(jù),也是通過association配置,但是另一個(gè)表的查詢通過select屬性配置。

13.Mybatis實(shí)現(xiàn)一對多有幾種方式,怎么操作的?

  • 有聯(lián)合查詢和嵌套查詢。聯(lián)合查詢是幾個(gè)表聯(lián)合查詢,只查詢一次,通過在resultMap里面的collection節(jié)點(diǎn)配置一對多的類就可以完成;嵌套查詢是先查詢一個(gè)表,再去另一表里查詢數(shù)據(jù),也是通過配置collection,但是另一表的查詢通過select節(jié)點(diǎn)配置。

以上就是動力節(jié)點(diǎn)小編介紹的"什么是Mybatis",希望對大家有幫助,想了解更多可查看Mybatis視頻教程。動力節(jié)點(diǎn)在線學(xué)習(xí)教程,針對沒有任何Java基礎(chǔ)的讀者學(xué)習(xí),讓你從入門到精通,主要介紹了一些Java基礎(chǔ)的核心知識,讓同學(xué)們更好更方便的學(xué)習(xí)和了解Java編程,感興趣的同學(xué)可以關(guān)注一下。 

提交申請后,顧問老師會電話與您溝通安排學(xué)習(xí)

免費(fèi)課程推薦 >>
技術(shù)文檔推薦 >>
主站蜘蛛池模板: 精品中文字幕制服中文 | 国产欧美亚洲三区久在线观看 | 亚洲综合久久综合激情久久 | 亚洲午夜精品一区二区 | 动漫美女h黄18动漫免费观看 | 夜夜爱成人免费网站 | 在线看成人片 | 亲热网站 | 黄色免费在线网站 | 一本大道道无香蕉综合在线 | 狠狠干婷婷 | 成人福利在线观看 | 色视频免费版高清在线观看 | 欧美综合亚洲 | 日韩欧美无线在码 | 狠狠狠| 中文字幕网站 | 五月天免费在线视频 | 亚洲性69影院在线观看 | 国产成人手机在线好好热 | 欧美日韩福利视频 | 色六月婷婷 | 成人性动漫高清免费观看网址 | 韩国在线观看日韩 | 日本人成大片在线 | 看成年女人免费午夜视频 | 在线免费视频一区 | 全色黄大色大片免费久久老太 | 国内自拍成人网在线视频 | 男人的天堂色偷偷之色偷偷 | 另类视频在线观看 | freexxxxⅹhd18日本 | 人喾交性专区免费看 | 最近中文字幕在线看免费视频 | 波多野结衣免费视频观看 | 亚洲色图综合 | 黄色一级毛片看一级毛片 | 成人激情文学 | 国产一级一片免费播放 | 91久久亚洲最新一本 | 国产亚洲人成网站天堂岛 |