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