當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
MyBatis-Plus 快速开始及详测 SpringBoot 集成Mybatis-Plus
生活随笔
收集整理的這篇文章主要介紹了
MyBatis-Plus 快速开始及详测 SpringBoot 集成Mybatis-Plus
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
MyBatis-Plus 快速開始及詳測
簡介
MyBatis-Plus (opens new window)(簡稱 MP)是一個 MyBatis (opens new window)的增強工具,在 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 操作智能分析阻斷,也可自定義攔截規則,預防誤操作
架構:
步驟:
-
建庫建表
DROP TABLE IF EXISTS user;CREATE TABLE user (id BIGINT(20) NOT NULL COMMENT '主鍵ID',name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',age INT(11) NULL DEFAULT NULL COMMENT '年齡',email VARCHAR(50) NULL DEFAULT NULL COMMENT '郵箱',PRIMARY KEY (id) ); DELETE FROM user;INSERT INTO user (id, name, age, email) VALUES (1, 'Jone', 18, 'test1@baomidou.com'), (2, 'Jack', 20, 'test2@baomidou.com'), (3, 'Tom', 28, 'test3@baomidou.com'), (4, 'Sandy', 21, 'test4@baomidou.com'), (5, 'Billie', 24, 'test5@baomidou.com'); -
創建項目
-
導入依賴
<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.1</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.2.4</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.13.1</version></dependency></dependencies> -
yaml 配置文件
server:port: 8484 spring:datasource:driver-class-name: com.mysql.cj.jdbc.Drivertype: com.alibaba.druid.pool.DruidDataSourceusername: rootpassword: // 這里用自己的密碼 下面的數據庫名也是一樣url: jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=UTC&useSSL=false&characterEncoding=utf8&serverTimezone=GMT -
pojo層 : 這里是使用lombok 的插件 簡單易寫(就是方便偷懶)
import com.baomidou.mybatisplus.annotation.TableName; import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor; import lombok.experimental.Accessors; @Data @AllArgsConstructor @NoArgsConstructor @Accessors(chain = true) // 這個也是lombok的注解 方便 鏈式書寫 @TableName(value = "user") public class User {private Long id;private String name;private Integer age;private String email; } -
mapper層
import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.crush.pojo.User;public interface UserMapper extends BaseMapper<User> {} -
config:
import com.baomidou.mybatisplus.annotation.DbType; import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor; import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration;//Spring boot方式 @Configuration public class MybatisPlusConfig {// 分頁 這里用的是mybatis-plus自帶的分頁@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;} }
詳細測試:
- 增刪改查齊全 mybatis-plus 自帶的單表增刪改查基本都測了
- 多表的感覺還是要像原來一樣 那樣子應該會更方便。
個人見解:
使用 Mybatis-Plus 感覺是方便快捷很多,給我一種 簡單的sql 語句要被干掉的感覺
因為我使用下來 單表的操作 根本不需要看到 sql 語句。
看了一些項目 多表的話 還是需要自己寫的 。
建議:
不過 mybatis-plus 它沒有寫sql 但是執行sql語句
里面的問題還是很值的探究 有興趣的一定要進去康康 多打打斷點
后面接著學的話 肯定還會接著更新滴 。
在這次學習中 發現一個技巧 如果什么不會了 立馬點進源碼里面慢慢看
再慢慢測試 這比看別人的博客和視頻 學習還會更快和更牢固一些。
共勉。
總結
以上是生活随笔為你收集整理的MyBatis-Plus 快速开始及详测 SpringBoot 集成Mybatis-Plus的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: org.junit.vintage.en
- 下一篇: MyBatis-Plus Day2 Wa