大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

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

什么是Mybatis

更新時間:2021-07-16 16:20:09 來源:動力節點 瀏覽1363次

1.什么是Mybatis?

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

2.Mybatis的優點

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

3.Mybatis框架的缺點

  • SQL語句的編寫工作量較大,尤其當字段多,關聯表多時,對開發人員編寫SQL語句的功底有一定要求。
  • SQL語句依賴數據庫,導致數據庫移植性差,不能隨意更換數據庫。

4.MyBatis框架使用場合

  • MyBatis專注于SQL本身,是一個足夠靈活的DAO層解決方案。
  • 對性能的要求很高,或者對需求變化較多的項目,如互聯網項目,MyBatis將是不錯的選擇。

5.Mybatis與Hibernate有哪些不同

  • Mybatis不完全是一個ORM框架,因為Mybatis需要程序員自己編寫SQL語句。
  • Mybatis直接編寫原生態SQL,可以嚴格控制SQL執行性能,靈活度高,非常適合對關系數據模型要求不高的軟件開發,因為這類軟件需求變化頻繁,一旦需求變化要求迅速輸出成果。但是靈活的前提是Mybatis無法做到數據庫無關性,如果需要實現支持多種數據庫的軟件,則需要自定義多套SQL映射文件,工作量大。
  • Hibernate對象/關系映射能力強,數據無關性好,對于關系模型要求高的軟件,如果用Hibernate開發可以節省很多代碼,提高效率。

6.Mybatis是如何進行分頁的?分頁插件的原理是什么?

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

7.Mybatis是如何將SQL執行結果封裝為目標對象并返回的?都有哪些映射形式?

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

8.Mybatis動態SQL有什么用?執行原理?有哪些動態SQL?

  • Mybatis動態SQL可以在xml映射文件內,以標簽的形式編寫動態sql,執行原理是根據表達式的值完成邏輯判斷并動態拼接SQL的功能。
  • Mybatis提供了9種動態SQL標簽:trim|where|set|foreach|if|choose|when|otherwise|bind

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

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

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

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

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

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

12.Mybatis實現一對一有幾種方式?具體是怎么操作的?

  • 有聯合查詢和嵌套查詢,聯合查詢是幾個表聯合查詢,只查詢一次,通過在resultMap里配置association節點配置一對一的類就可以完成。
  • 嵌套查詢是先查詢一個表,根據這個表里的結果的外鍵id,再去另一表里查詢數據,也是通過association配置,但是另一個表的查詢通過select屬性配置。

13.Mybatis實現一對多有幾種方式,怎么操作的?

  • 有聯合查詢和嵌套查詢。聯合查詢是幾個表聯合查詢,只查詢一次,通過在resultMap里面的collection節點配置一對多的類就可以完成;嵌套查詢是先查詢一個表,再去另一表里查詢數據,也是通過配置collection,但是另一表的查詢通過select節點配置。

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

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 色片免费观看 | 99热爱| 欧美在线小视频 | 色骚综合| 高清国产精品入口麻豆 | 欧美日韩一区二区三在线 | 久久综合亚洲伊人色 | 狠狠色综合久久婷婷 | 国内精品免费一区二区观看 | 久久久精品久久久久久 | 波多野给衣一区二区三区 | 天天天天天天天操 | 一级特级女人18毛片免费视频 | 成人a毛片久久免费播放 | 国产精品福利影院 | 99av视频| 免费在线成人网 | 欧美日韩福利视频一区二区三区 | 亚洲国产欧美国产第一区二区三区 | 亚洲天天在线日亚洲洲精 | 嫩模一区 | 麻豆精品国产免费观看 | 日本欧美强乱视频在线 | 亚洲欧美成人在线 | 97视频在线免费播放 | 老色99久久九九精品尤物 | 精品九九九 | 天天操天天射天天爽 | 久久中文亚洲国产 | 一级毛片成人免费看免费不卡 | 9966久久精品免费看国产 | 成人网欧美亚洲影视图片 | 91精品国产91久久综合 | 亚洲精品www久久久久久久软件 | 国产一区二区在线播放 | 久热精品视频在线观看 | 成人美女免费网站视频 | 久久伊人操 | 北条麻妃手机在线观看 | 亚洲视频免费在线 | 久久婷婷人人澡人人爱91 |