MyBatis-Plus速成指南之簡化你的數(shù)據(jù)庫操作流程(最新推薦)
簡介:
- MyBatis-Plus 是一個 MyBatis 的增強工具,在 MyBatis 的基礎(chǔ)上只做增強不做改變,為簡化開發(fā)、提高效率而生。
- MyBatsi-Plus 提供了通用的 Mapper 和 Service,可以不編寫任何 SQL 語句的前提下,快速的實現(xiàn)單表的增刪改查(CURD),批量邏輯刪除,分頁等操作。只要把 MyBatis-Plus 的特性優(yōu)秀插件,以及多數(shù)據(jù)源的配置進行詳細講解
特性:
- 無入侵:只做增強不做改變,引入它不會對現(xiàn)有工程產(chǎn)生影響
- 損耗?。簡蛹磿詣幼⑷牖?CURD,性能基本無損耗,直接面向?qū)ο蟛僮?/li>
- 強大的 CURD 操作,更有強大的條件構(gòu)造器,滿足各類使用需求
- 支持 Lambda 形式調(diào)用:同過 Lambda 表達式,方便的編寫各類條件查詢,無需擔(dān)心字段寫錯
- 支持主鍵自動生成:支持多達 4 種主鍵策略(內(nèi)含分布式唯一 ID 生成器 - Sequence),可自由配置,完美解決主鍵問題
- 支持自定義全局通用操作:支持全局方法注入(Write once、use anywhere)
- 內(nèi)置代碼生成器:采用代碼或者 Maven 插件可快速生成 Mapper、Model、Service、Controller 層代碼,支持模板引擎
- 內(nèi)置分頁插件:基于 MyBatis 物理分頁,開發(fā)者無需關(guān)心具體操作,配置好插件后,寫分頁等同于 List 查詢
- 分頁插件支持多種數(shù)據(jù)庫:支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多種數(shù)據(jù)庫
- 內(nèi)置性能分析插件:可輸出 SQL 語句以及其執(zhí)行時間,建議開發(fā)測試時啟用該功能,能快速救出慢查詢
- 內(nèi)置全局攔截插件:提供全表delete、update操作,只能分析阻斷,也可自定義攔截規(guī)則,預(yù)防誤操作
支持數(shù)據(jù)庫:
- MySQL、Oracle、DB2、H2、HSQL、SQLite、PostgreSQL、SQLServer、Phoenix、Gauss、ClickHouse、Sybase、OceanBase、Firebird、Cubrid、Foldilocks、csiidb
框架結(jié)構(gòu):
代碼及文檔地址:
官方地址:http://mp.baomidou.com
代碼發(fā)布地址:
GitHub:GitHub - baomidou/mybatis-plus: An powerful enhanced toolkit of MyBatis for simplify development
Gitee:mybatis-plus: mybatis 增強工具包,簡化 CRUD 操作。 文檔 http://baomidou.com低代碼組件庫 http://aizuda.com
文檔發(fā)布地址:https://baomidou.com/pages/24112f
入門案例:
創(chuàng)建數(shù)據(jù)庫和表:
CREATE DATABASE `mybatis_plus` /*!40100 DEFAULT CHARACTERSET utf8mb4 */; use `mybatis_plus`; CREATE TABLE `user` ( `id` bigint(20) NOT NULL COMMENT '主鍵ID', `name` varchar(30) DEFAULT NULL COMMENT '姓名 ', `age` int(11) DEFAULT NULL COMMENT '年齡 ', `email` varchar(50) DEFAULT NULL COMMENT '郵箱 ', PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; 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');
創(chuàng)建 SpringBoot 工程 初始化工程:
導(dǎo)入依賴:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.5.1</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>runtime</scope> </dependency>
IDEA 中安裝 Lombok 插件:
編寫代碼:
application.yml
spring: # 配置數(shù)據(jù)源信息 datasource: # 配置數(shù)據(jù)源類型 type: com.zaxxer.hikari.HikariDataSource # 配置連接數(shù)據(jù)庫信息 driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/mybatis_plus?characterEncoding=utf-8&useSSL=false username: root password: root
注意:
驅(qū)動類:driver-class-name
SpringBoot 2.0(內(nèi)置 jdbc5驅(qū)動),驅(qū)動類使用:driver-class-name:comment.mysql.jdbc.Driver
SpringBoot 2.1及以上(內(nèi)置 jdbc8 驅(qū)動),驅(qū)動類使用:driver-class-name:comment.mysql.cj.jdbc.Driver
連接地址 URL:
MySQL5.7 的版本 url:
jdbc:mysql://localhost:3306/mybatis-plus?characterEncoding=utf-8&useSSl=false
MySQL8.0 版本的URL:
jdbc:mysql://localhost:3306/mybatis_plus?serverTimezone=GMTZ%2B8&characterEncoding=utf-8&useSSL=false
否則運行測試用例報如下錯誤:
a.java.sql.SQLException:The server timezone value'Öйú±ê׼ʱ¼ä' is unrecognized or representsmore
啟動類:
在 SpringBoot 啟動類中添加 @MapperScan 注解,掃描 mapper 包
@SpringBootApplication @MapperScan("com.qcby.mybatisplus.mapper") public class MybatisplusApplication { public static void main(String[] args) { SpringApplication.run(MybatisplusApplication.class, args); } }
添加實體類:
@Data public class User { private Long id; private String name; private Integer age; private String email; }
添加 Mapper:
BaseMapper 時 MyBatis-Plus 提供的 mapper 模板,其中包含了基本的 CURD 方法,泛型為操作的實體類型
public interface UserMapper extends BaseMapper<User> { }
測試:
@SpringBootTest public class MyBatisPlusApplicationTests { @Autowired private UserMapper userMapper; @Test public void contextLoads() { //selectList() 根據(jù) MP 內(nèi)置的條件構(gòu)造器查詢一個 list 集合,null 表示沒有條件,即查詢所有 userMapper.selectList(null).forEach(System.out::println); } }
添加日志:
在 application.yml 中配置日志輸出
# 配置MyBatis日志 mybatis-plus: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
結(jié)果:
注意:
- IDEA 在 userMapper 處報錯,因為找不到注入的對象,因為類是動態(tài)創(chuàng)建的,但是程序可以正確的運行
- 為了避免報錯,可以在 mapper 接口上添加 @Repository 注解
到此這篇關(guān)于MyBatis-Plus速成指南:簡化你的數(shù)據(jù)庫操作流程的文章就介紹到這了,更多相關(guān)MyBatis-Plus數(shù)據(jù)庫操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring Boot LocalDateTime格式化處理的示例詳解
這篇文章主要介紹了Spring Boot LocalDateTime格式化處理的示例詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10Springboot?注解EqualsAndHashCode詳解
注解@EqualsAndHashCode主要用于自動生成equals方法和hashCode方法,callSuper屬性為true時,生成的方法會包括父類字段,為false則只包含當前類字段,IDEA工具中有檢查提示并可自動修復(fù)相關(guān)代碼,確保注解正確使用,更多詳解可查閱相關(guān)文檔2024-10-10SpringBoot中過濾器Filter+JWT令牌實現(xiàn)登錄驗證
本文主要介紹了SpringBoot中過濾器Filter+JWT令牌實現(xiàn)登錄驗證,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-04-04解決報錯:java.lang.IllegalStateException: Failed to&nb
在項目開發(fā)中,可能會遇到Elasticsearch啟動報錯的問題,原因可能包括版本不一致、端口配置錯誤、配置文件不匹配及服務(wù)未啟動等,解決方法包括檢查進程、重啟服務(wù)等,這些經(jīng)驗可以幫助開發(fā)者快速定位問題并解決,保證項目順利運行2024-10-10springboot使用國產(chǎn)加密算法方式,sm2和sm3加解密demo
這篇文章主要介紹了springboot使用國產(chǎn)加密算法方式,sm2和sm3加解密demo,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07Mybatis mapper標簽中配置子標簽package的坑及解決
這篇文章主要介紹了Mybatis mapper標簽中配置子標簽package的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09關(guān)于SpringBoot打包測試、生產(chǎn)環(huán)境方式
這篇文章主要介紹了關(guān)于SpringBoot打包測試、生產(chǎn)環(huán)境方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-09-09