阿里一手爆出:Springboot整合MybatisPlus(超详细)完整教程

开发工具:idea2019.2,men3

mybatisplus文档 mybatis3文档mybatisplus文档 mybatis3文档


mybatisplus文档 mybatis3文档


建表:

执行GeneratorCodeConfig.ja文件,输入表名user:

解决方法:在数据库连接中配置添加allowPublicKeyRetrieval=true

查看生成的文件;

启动springboot的application启动类:会报错,提示找不到mapper文件,我们需要在springboot启动类上添加扫描mapper的注解:

UserController.ja中新增接口:

tman测试:

没问题。

上面是mybatisplus测试成功,下面我们继续测试我们自己写的sql是否成功。

在resources目录下新建mapper文件夹,新建UserMapper.xml文件:

UserMapper.ja

IUserServ:

UseServImpl.ja:

UserController.ja:

测试findAllUser接口:

常用的工具类:

ResultInfo.ja

Status.ja

一份详尽的yml配置文件(关于数据源的配置比较详尽):

总结:

所有的面试题目都不是一成不变的,特别是像一线大厂,上面的资料只是给大家一个借鉴作用,主要的是给自己增加知识的储备,有备无患。给大家分享Spring系列的学习笔记和面试题,包含spring面试题、spring cloud面试题、spring boot面试题、spring教程笔记、spring boot教程笔记、阿里巴巴开发手册(63页PDF总结)、2022年Ja面试手册。一共整理了1184页PDF文档。私信博主(777)领取,祝大家更上一层楼!!!

原文作者:易水寒

原文出处:

Mybatis-plus之分页泛型转换

对于vo和po严格规范的同学来说,在使用mybatis-plus进行分页时每次都需要分页信息或者重写分页api。其实mybatis-plus早已为我们解决这个问题了,细心的同学会发现在IPage中有一个convert方法,没错!就是这个方法。以后写分页就可以这样写了

其源码如下:

可知,其做了一个泛型的强制转换,同时保留了分页信息。

SpringBoot+Mybatis-Plus两种分页方法

首先配置mybatis-plus配置

种方式,mybatis-plus原生QueryWrapper方式分页,这种方式比较简单,可以不用修改Mapper,适合简单的增删改查。

第二种方式,使用mapper文件的select注解,优点是可以方便的建立查询语句,可以联合多表查询。

Mapper文件

Controller文件

Spring Boot(十一):MyBatis插件之MyBatis-Plus

MyBatis的插件MyBatis-Plus,又叫苞米豆(baomidou),简称MP,说,它是为了猿类崛起而生,为了提高生产率而生,为了简化开发而生,不管它为了什么而生吧,反正是它出生了。

MyBatis-Plus对MyBatis只做增强不做改变,所以引入它不会对现有工程产生影响,只需要做简单的配置,就可以快速进行单表的CRUD作,从而节省时间,提高效率。

MyBatis-Plus插件有很丰富的功能,比如:单表CRUD作、代码生成、自动分页、逻辑删除等。

下面我们来简单介绍一下MyBatis-Plus的使用

1、pom.xml

去掉MyBatis的核心依赖(org.mybatis.spring.boot.mybatis-spring-boot-starter),增加MyBatis-Plus的依赖:

2、配置application.yml、po、dao和Application

application.yml中配置数据库连接:

blog数据库中article表的实体类ArticlePo:

注解说明:

@TableName:表名注解,标识实体类对应的表

@TableId注解:主键注解,当type = IdType.AUTO时,表示这个主键是自增主键

blog数据库中article表的dao,ArticleDao:

BaseMapper接口:利用Mybatis接口编程的实现机制,默认提供了一系列的增删改查的基础方法。

在Article11Application中配置 MapperScan 注解:

3、增加数据

insert:增加数据,insert返回值int代表insert了多少条记录

示例:在ArticleController中编写增加数据的接口:

说明:

1)一般业务逻辑处理在serv层,这里为了方便,直接在controller中演示了

2)@Resource注解:注入ArticleDao,后续的方法中不再重复注入

4、删除数据

delete:物理删除数据,返回删除了多少条数据

示例,删除title为Mybatis-Plus test的数据:

说明:

1)物理删除后,恢复数据很困难,所以一般情况下,业务处理采用逻辑删除的方式

5、更新数据

update: 更新数据

示例,修改title为Mybatis-Plus test的数据的title为Mybatis-Plus update:

updateById: 根据主键id更新数据

示例,修改id为7的数据的title为Mybatis-Plus updateById:

注意 :

1、updateById方法:若传入实体Model,则会根据主键把其他字段全部更新一遍

问题:使用baomidou拿出某条数据的数据实体后,有其他人把数据库中这条数据的某个字段更新了,再用baomidou的updateById方法更新时,会把此字段再更新回来

解决:

方法1:使用sql语句,只更新需要更新的字段

方法2:新建实体Model,Model中只放主键和需要更新的字段

6、查询数据

selectOne: 查询单条数据

示例,查询id为7的数据:

注意 :

1、selectOne方法

1)结果没有数据时,返回null

2)结果有一条数据时,返回此数据

3)结果有两条或两条以上数据时,报错

解决办法:在增加 .last(" limit 1 ") 语句

selectList: 查询多条数据

示例:查询title为Mybatis-Plus update的数据

7、打印sql日志

打印执行的sql,在application.yml中配置,一般配置在开发环境

MyBatis-Plus的其他注意事项

1、如果数据库表字段中有desc、describe等mysql或预留,使用selectList/selectOne会报错,需要单独写sql查询语句

2、有时我们需要在Dao中单独写方法来写sql语句,这时方法的命名跟baomidou自带的命名不要一样,否则即使参数不同,也会有问题:Dao中单独写的方法,会把baomidou的方法覆盖,就调用不到baomidou的方法了

本文示例代码, 详见

若您觉得还可以,请帮忙点个 “赞” ,谢谢

SpringBoot整合MyBatisPlus配置动态数据源

MybatisPlus特性

快速开始

初始化测试数据表:

父工程依赖

该工程用于依赖管理,pom如下:

创建MyBaitsPlus工程

依赖如下:

properties配置

在这里配置数据库连接,以及数据连接池与mybatisplus的配置等

常规增删改查实现

创建实体类:

该lombok插件省去getset方法。

创建UserMapper接口,并且实现BaseMapper这里我们指定实体类为user可直接使用接口中的方法。

UserMapper.xml,如下:

执行SQL:

在SpringBoot中使用MybatisPlus分页需要注入Bean,并且在启动类上使用@MapperScan("com..spring.boot.mapper")扫描mapper文件路径如下:

使用MyBatisPlus可以为我们减少很多很多的代码,不过需要编写实体类,有失必有得。

配置动态数据源

dynamic-datasource-spring-boot-starter 是一个基于springboot的快速集成多数据源的启动器。

优势

网上关于动态数据源的切换的文档有很多,核心只有两种。

如果你的数据源较少,场景不复杂,选择以上任意一种都可以。如果你需要更多特性,请尝试本动态数据源。

劣势

不能使用多数据源事务(同一个数据源下能使用事务),网上其他方案也都不能提供。

如果你需要使用到分布式事务,那么你的架构应该到了微服务化的时候了。

如果呼声强烈,项目达到800 star,作者考虑集成分布式事务。

PS: 如果您只是几个数据库但是有强烈的需求分布式事务,建议还是使用传统方式自己构建多套环境集成atomic这类,网上百度很多。

约定

建议

强烈建议在 主从模式 下遵循普遍的规则,以便他人能更轻易理解你的代码。

主数据库 建议 只执行 INSERT UPDATE DELETE 作。

从数据库 建议 只执行 SELECT 作。

快速开始

加入依赖:

注释掉原来的数据库配置,加入:

使用 @DS 切换数据源。

@DS 可以注解在方法上和类上, 同时存在方法注解优先于类上注解 。

注解在serv实现或mapper接口方法上,但强烈不建议同时在serv和mapper注解。 (可能会有问题)

如果不加入主键则使用默认数据源。

DruidDataSourceAutoConfigure会注入一个DataSourceWrapper,其会在原生的spring.datasource下找,username,password等。而我们动态数据源的配置路径是变化的,所以需要排除:

或者在类上排除:

然后更换properties配置信息:

本篇代码案例地址:

作者:SimpleWu

出处:

mybatis+创建文档实例错误?

如果您在使用MyBatis-Plus创建文档实例时出现错误,可能是以下几个方面导致的:

实体类没有继承父类Model

在使用MyBatis-Plus创建文档实例时,需要保证实体类继承了父类Model,例如:

csharpCopy codepublic class User extends Model { // ...}

实体类的属性没有添加@TableField注解

在实体类中需要添加@TableField注解,用于指定实体类的属性对应数据库表中的列名,例如:

kotlinCopy codepublic class User extends Model { @TableField("user_name")

private String userName; // ...}

实体类的主键没有添加@TableId注解

在实体类中需要添加@TableId注解,用于指定实体类的主键对应数据库表中的主键列名,例如:

kotlinCopy codepublic class User extends Model { @TableId("id")

private Long id; // ...}

缺少依赖

使用MyBatis-Plus创建文档实例需要依赖MyBatis-Plus和MyBatis框架,如果您没有正确添加这些依赖,可能会导致出现错误。请确保您的项目中正确添加了以下依赖:

phpCopy code

com.baomidou

mybatis-plus-boot-starter

版本号

org.mybatis

mybatis

版本号

如果您仍然无法解决问题,请提供更具体的错误信息或代码,以便更好地帮助您解决问题。

Spring Boot(十二):MyBatis-Plus的多数据源和分页

同一个项目有时会涉及到多个数据库,这时我们就要配置多个数据源。配置多数据源的常见情况有以下两种:

1)同一个项目中涉及两个或多个业务数据库,它们之间相互,这种情况也可以作为两个或多个项目来开发

2)两个或多个数据库之间是主从关系,主库负责写,从库负责读

1、pom.xml配置

在pom.xml中增加MyBatis-Plus多数据源依赖:

2、配置文件配置

在配置文件application.yml中配置我们需要连接的数据库:blog和user,默认为blog

3、启动类配置

在@SpringBootApplication注解上增加exclude = DruidDataSourceAutoConfigure.class配置:

这个配置的作用是去掉对DruidDataSourceAutoConfigure的自动配置,否则程序会报错:

原因:

DruidDataSourceAutoConfigure在DynamicDataSourceAutoConfiguration之前,其会注入一个DataSourceWrapper,会在原生的spring.datasource下找, username, password等,而我们动态数据源的配置路径是变化的。

4、实体类和dao层配置

在po文件夹下创建blog和user文件夹,分别用于存储blog数据库和user数据库的实体:

注解:

@TableName: 表名注解,标识实体类对应的表

@TableId: 主键注解,当type = IdType.AUTO时,表示这个主键是自增主键

在dao文件夹下创建blog和user文件夹,分别用于存储blog和user的dao:

注解:

@Reitory: 将数据访问层(DAO层)的类标识为Spring Bean

@DS: 配置非默认数据源,本示例中blog为默认数据源,user为非默认数据源,在使用@DS注解时,有如意事项:

1)不能使用事务,否则数据源不会切换,使用的还是次加载的数据源

2)次加载数据源之后,第二次,第三次……作其他数据源,如果数据源不存在,使用的还是次加载的数据源

3)数据源名称不要包含下划线,否则不能切换

5、测试验证

编写ArticleController和UserInfoController:

注 : 业务逻辑复杂时,Controller和Mapper中间会有Serv层来处理业务逻辑,现在我们就简单的测试一下多数据源,所以直接使用Controller调用Mapper了

1、配置分页插件

2、分页方法

1)使用MyBatis-Plus的selectPage方法

使用MyBatis-Plus的selectPage方法,返回了IPage,示例:

2)sql分页

有时候有些分页需要关联多张表,使用LambdaQueryWrapper不太方便,这时候可以自己写sql来实现分页,主要有两种:纯sql自己实现分页和使用IPage实现分页

注 : 这里的sql示例就使用单表查询了,具体的可根据业务场景使用多表查询

A、纯sql自己实现分页

分页的数据list和总条数单独调用方法返回 :

B、使用IPage实现分页(常用)

返回IPage,返回值的数据结构见“ 1)使用MyBatis-Plus的selectPage方法 ”

本文简单介绍了一下MyBatis-Plus的多数据源和分页,本文示例代码, 详见s://

若您觉得还可以,请帮忙点个 “赞” ,谢谢