前言
在上節中,我們已經講過了MyBatis
相關知識,大家有興趣的話可參考以下文章
SpringBoot(38) — MyBatis之Java註解方式增刪改查
今天讓我們來學習下MyBatis-plus
的相關知識。
涉及知識有:
-
MyBatis-plus
簡介 -
MyBatis-plus
與MyBatis
區別 -
MyBatis-plus
官網
一. MyBatis-plus 簡介
MyBatis-plus
簡稱mp
,是一個 MyBatis的增強工具,在 MyBatis 的基礎上只做增強不做改變,爲簡化開發、提高效率而生。
具有以下特性:
- 無侵入:只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑
- 損耗小:啓動即會自動注入基本 CURD,性能基本無損耗,直接面向對象操作
- 強大的 CRUD 操作:內置通用 Mapper、通用 Service,僅僅通過少量配置即可實現單表大部分 CRUD 操作,更有強大的條件構造器,滿足各類使用需求
- 支持 Lambda 形式調用:通過 Lambda 表達式,方便的編寫各類查詢條件,無需再擔心字段寫錯
- 支持主鍵自動生成:支持多達 4 種主鍵策略(內含分佈式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問題
- 支持 ActiveRecord 模式:支持 ActiveRecord 形式調用,實體類只需繼承 Model 類即可進行強大的 CRUD 操作
- 支持自定義全局通用操作:支持全局通用方法注入( Write once, use anywhere )
- 內置代碼生成器:採用代碼或者 Maven 插件可快速生成 Mapper 、 Model 、 Service 、 Controller 層代碼,支持模板引擎,更有超多自定義配置等您來使用
- 內置分頁插件:基於 MyBatis 物理分頁,開發者無需關心具體操作,配置好插件之後,寫分頁等同於普通 List 查詢
- 分頁插件支持多種數據庫:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種數據庫
- 內置性能分析插件:可輸出 SQL 語句以及其執行時間,建議開發測試時啓用該功能,能快速揪出慢查詢
- 內置全局攔截插件:提供全表 delete 、 update 操作智能分析阻斷,也可自定義攔截規則,預防誤操作
二. MyBatis-plus 與 MyBatis 區別
- 值得注意的是,
MyBatis-plus
只在MyBatis
基礎上做增強,這表示當我們使用MyBatis-plus
框架時,也可以使用MyBatis
特性。 - 當我們引用了
MyBatis-plus
框架後,就不要再引用MyBatis
框架了,因爲每個MyBatis-plus
版本對對應一個特定的MyBatis
版本,如果MyBatis-plus
與MyBatis
同時引用不僅會造成引用重複,還會出現MyBatis-plus
與MyBatis
版本不一致的尷尬局面。 -
MyBatis
使用側重於xml
文件操作,即還是很大程度上依賴於sql
語句的操作,但是MyBatis-plus
可以將我們完全從sql
語句中解放出來,我們可以用簡潔的Java
代碼實現數據庫的CRUD
。
三. MyBatis-plus 官網
學習更多MyBatis-plus
知識,我們可以參看MyBatis-plus 官網