當前位置:編程學習大全網 - 源碼下載 - MyBatis?Plus快速入門源碼筆記***享,拿走吧妳

MyBatis?Plus快速入門源碼筆記***享,拿走吧妳

為什麽要學習它呢?

答:MyBatisPlus可以節省我們大量工作時間,所有的CRUD代碼它都可以自動化完成!

優點:

1. 易於上手和掌握。

2. sql寫在xml裏,便於統壹管理和優化。

3. 解除sql與程序代碼的耦合。

4. 提供映射標簽,支持對象與數據庫的orm字段關系映射

5. 提供對象關系映射標簽,支持對象關系組建維護

6. 提供xml標簽,支持編寫動態sql。

MyBatis Plus(簡稱 MP)是壹個 MyBatis的增強工具,在 MyBatis 的基礎上只做增強不做改變,為簡化開發、提高效率而生。

就像 魂鬥羅 中的 1P、2P,基友搭配,效率翻倍。

特性:

無侵入 :只做增強不做改變,引入它不會對現有工程產生影響,如絲般順滑。

損耗小 :啟動即會自動註入基本 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 操作智能分析阻斷,也可自定義攔截規則,預防誤操作。

1.1 、引入mybatis-plus相關maven依賴

引入mybatis-plus在spring boot中的場景啟動器

ps:切記不可再在pom.xml文件中引入mybatis與mybatis-spring的maven依賴,這壹點,mybatis-plus的官方文檔中已經說明的很清楚了.

1.2、創建數據表

(1)SQL語句

(2) 數據表結構

1.3、 創建java bean

根據數據表新建相關實體類

1 package com.example.demo.pojo

1.4、 配置application.proprties

數據源使用druid

ps:在進行crud實驗之前,簡單對mybatis與mybatis-plus做壹個簡單的對比

2.1、mybatis與mybatis-plus實現方式對比

(1)提出問題: 假設我們已存在壹張 tbl_employee 表,且已有對應的實體類 Employee,實現 tbl_employee 表的 CRUD操作我們需要做什麽呢?

(2)實現方式: 基於 Mybatis 需要編寫 EmployeeMapper 接口,並手動編寫 CRUD 方法 提供 EmployeeMapper.xml 映射文件,並手動編寫每個方法對應的 SQL 語句. 基於 Mybatis-plus 只需要創建 EmployeeMapper 接口, 並繼承BaseMapper 接口.這就是使用 mybatis-plus 需要完成的所有操作,甚至不需要創建 SQL 映射文件。

2.2、BaseMapper接口介紹

(1)如何理解核心接口BaseMapper?

在使用Mybatis-Plus時,核心操作類是BaseMapper接口,其最終也是利用的Mybatis接口編程的實現機制,其默認提供了壹系列的增刪改查的基礎方法,並且開發人員對於這些基礎操作不需要寫SQL進行處理操作(Mybatis提供的機制就是需要開發人員在mapper.xml中提供sql語句),那樣我們可以猜測肯定是Mybatis-Plus完成了BaseMapper接口提供的方法的SQL語句的生成操作。

(2)BaseMapper接口為我們定義了哪些方法?

BaseMapper接口源碼:

(3) mybatis-plus中常用的註解 1

由於我們的數據表名於實體類的類名不壹致,並且實體類於數據表還存在字段名不對應的情況,因此我們需要引入mybatis-plus的註解.

編寫EmployeeMapper接口繼承BaseMapper接口

準備考試環境:

(1)插入

(2)修改

控制臺打印出的sql語句

如果我們不設置實體類的email與gender屬性,結果是怎樣的呢?

控制臺sql語句:

顯然,mybatis-plus為我們做了非空判斷,空值的話,默認不更新對應的字段.想壹想,這是不是類似於mybatis中的動態sql呢?

這種處理效果又會帶來什麽好處呢?

(3)查詢

selectById方法

selectBatchIds方法

ps:發現該方法底層使用的竟然是sql的in關鍵字

selectByMap方法

(4)刪除

3、不得不提的條件構造器---Wrapper

3.1.wrapper及其子類介紹

(1)Wrapper :條件構造抽象類,最頂端父類,抽象類中提供3個方法以及其他方法.

  • 上一篇:請求源代碼分析
  • 下一篇:教妳如何使用C語言編寫簡單小遊戲
  • copyright 2024編程學習大全網