mybatis mapper文件找不到_MyBatis 面试题
1. 什么是 Mybatis?
MyBatis 是一個支持自定義 SQL、存儲過程以及高級映射的持久層框架。 MyBatis 免除了幾乎所有的 JDBC 代碼以及設置參數和獲取結果集的工作。
Mybati可以使用XML或注解來配置和映射原生信息,將POJO映射成數據庫中的記錄,避免幾乎所有JDBC代碼和手動設置參數以及獲得結果集。
2. MyBatis 框架的優點:
基于SQL語句編程,相當靈活,不會對應用程序或者數據庫的現有設計造成任何影響,SQL寫在XML文件中,接觸SQL與程序代碼的耦合,便于統一管理;提供XML便簽,支持編寫動態SQL語句,并可以重用。
與JDBC相比,減少了50%以上的代碼量,消除了JDBC大量冗余的代碼,不需要手動開關連接。
很好的與各種數據庫兼容(因為MyBatis使用JDBC來連接數據,所以只要JDBC支持數據庫MyBatis都支持)。
能夠與Spring框架很好的集成。
提供映射標簽,支持對象與數據庫的ORM字段關系映射;提供對象關系映射標簽,支持對象關系組件維護。
3. MyBatis 框架的缺點:
1.SQL語句的編寫工作量較大,尤其當字段多,關聯表多時,對開發人員編寫SQL語句的功底有一定要求。
2.SQL語句依賴數據庫,導致數據庫移植性差,不能隨意更換數據庫。
4. MyBatis 框架適用場合:
適用于對性能的要求很高,或者對需求變化較多的項目,如互聯網項目。
5. MyBatis 與 Hibernate 有哪些不同?
Mybatis不完全是一個ORM框架,因為Mybatis需要程序員自己編寫SQL語句。
Mybatis直接編寫原生態SQL,可以嚴格控制SQL執行性能,靈活度高,非常適合對關系數據模型要求不高的軟件開發,因為這類軟件需求變化頻繁,一旦需求變化要求迅速輸出成果。但是靈活的前提是Mybatis無法做到數據庫無關性,如果需要實現支持多種數據庫的軟件,則需要自定義多套SQL映射文件,工作量大。
Hibernate對象/關系映射能力強,數據無關性好,對于關系模型要求高的軟件,如果用Hibernate開發可以節省很多代碼,提高效率。
6. #{}和${}的區別是什么?
#{} 在預處理時,會把參數部分用一個占位符 ? 代替。
${} 則只是簡單的字符串替換。
#方式能夠很大程度防止sql注入,$方式無法防止Sql注入。
7. 當實體類中的屬性名和表中的字段名不一樣 ,怎么辦 ?
方法一:通過在查詢的SQL語句中定義字段名的別名的方式,讓字段名的別名和實體類中的屬性名一致,這樣就可以實現實體類屬性和表字段一一對應。
方法二:通過<resultMap>來映射字段名和實體類屬性名的一一對應關系。
8. 模糊查詢 like 語句該怎么寫?
第一種在java中的dao或service層或者controller層傳值的時候寫上%%號
第二種使用CONCAT
第三種在mapper中做字符串拼接處理
9. 通常一個 Xml 映射文件,都會寫一個 Dao 接口與之對應,請問,這個 Dao 接口的工作原理是什么?Dao 接口里的方法,參數不同時,方法能重載嗎?
10. Mybatis 是如何進行分頁的?分頁插件的原理是什么?
MyBatis使用RowBounds對象進行分頁,它是針對ResultSet結果集執行的內存分頁而非物理分頁。可以在SQL內直接書寫帶有物理分頁的參數來完成分頁功能。也可以使用分頁插件來完成物理分頁。
分頁插件的基本原理是使用Mybatis提供的插件接口,實現自定義插件,在插件的攔截方法內攔截執行的SQL,然后重新SQL,根據dialect方言,添加對應的物理分頁語句和物理分頁參數。
11. Mybatis是如何將sql執行結果封裝為目標對象并返回的?都有哪些映射形式?
第一種是使用標簽:逐一定義數據庫列明和對象屬性名之間的映射關系。
第二種是使用SQL列的別名功能:將列的別名書寫為對象屬性名。
有了列名和屬性名的映射關系后,Mybatis通過反射創建對象,同時使用反射給對象的屬性逐一賦值并返回,那些找不到映射關系的屬性是無法賦值的。
12. 如何執行批量插入?
foreach標簽
13. 如何獲取自動生成的(主)鍵值?
selectKey標簽
14. 在 mapper 中如何傳遞多個參數?
以對象的方式傳入多個參數
15. Mybatis 動態 sql 有什么用?執行原理?有哪些動態 sql?
1)根據傳入參數不同, 動態拼接sql。
2)
3)判斷類標簽: if, choose, when, otherwise
拼接截斷類標簽: trime, where, set
循環類標簽: foreach
自定義遍歷標簽: bind
16. Xml 映射文件中,除了常見的 select|insert|updae|delete標簽之外,還有哪些標簽?
判斷類標簽: if, choose, when, otherwise
拼接截斷類標簽: trime, where, set
循環類標簽: foreach
自定義遍歷標簽: bind
selectKey標簽
17. 為什么說 Mybatis 是半自動 ORM 映射工具?它與全自動的區別在哪里?
Hibernate屬于全自動的ORM映射工具,使用Hibernate查詢關聯對象或者關聯集合對象時,可以根據對象關系模型直接獲取,所以它是全自動的。而Mybatis在查詢關聯對象或關聯集合對象時,需要手動編寫SQL來完成,所以稱之為半自動ORM映射工具。
18. 一對一、一對多的關聯查詢 ?
19. MyBatis 實現一對一有幾種方式?具體怎么操作的?
有聯合查詢和嵌套查詢,
聯合查詢是幾個表聯合查詢,只查詢一次,通過在resultMap里配置association節點配置一對一的類就可以完成。
嵌套查詢是先查詢一個表,根據這個表里的結果的外鍵id,再去另一表里查詢數據,也是通過association配置,但是另一個表的查詢通過select屬性配置。
20. MyBatis 實現一對多有幾種方式,怎么操作的?
有聯合查詢和嵌套查詢。
聯合查詢是幾個表聯合查詢,只查詢一次,通過在resultMap里面的collection節點配置一對多的類就可以完成;
嵌套查詢是先查詢一個表,再去另一表里查詢數據,也是通過配置collection,但是另一表的查詢通過select節點配置。
21. Mybatis 是否支持延遲加載?如果支持,它的實現原理是什么?
mybatis支持延遲加載
適用場景
一對一,多對一 立即加載
一對多,多對多 延遲加載
原理:使用CGLIB創建目標對象的代理對象,當調用目標方法時,進入攔截器方法,
22. Mybatis 的一級、二級緩存:
一級緩存也叫sqlSession級別的緩存 ,也就是在同一個sqlSession內執行兩次多次相同結果的查詢語句,只會在第一次時發出sql查詢數據庫的數據,然后之后每次從一級緩存中查詢數據返回。
二級緩存是mapper級別的緩存,也就是多個sqlSession之間可以實現數據的共享,二級緩存默認是不開啟.
23. 什么是 MyBatis 的接口綁定?有哪些實現方式?
24. 使用 MyBatis 的 mapper 接口調用時有哪些要求?
25. Mapper 編寫有哪幾種方式?
1. 接口實現類集成SQLSessionDaoSupport 此方法需要編寫mapper接口,mapper接口的實現類,mapper.xml文件。
2. 使用org.mybatis.spring.mapper.MapperFactoryBean 此方法需要在SqlMapConfig.xml中配置mapper.xml的位置,還需定義mapper接口。
3. 使用mapper掃描器 需要編寫mapper.xml文件,需要mapper接口,配置mapper掃描器,使用掃描器從spring容器中獲取mapper的實現對象。
26. 簡述 Mybatis 的插件運行原理,以及如何編寫一個插件。
總結
以上是生活随笔為你收集整理的mybatis mapper文件找不到_MyBatis 面试题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mybatis源码_MyBatis架构和
- 下一篇: python if name main