SpringBoot整合MyBatisPlus配置动态数据源

SpringBoot整合MyBatisPlus配置动态数据源,第1张

MybatisPlus特性

快速开始

初始化测试数据表:

父工程依赖

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

创建MyBaitsPlus工程

依赖如下:

properties配置

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

常规增删改查实现

创建实体类:

该lombok插件省去getset方法

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

UserMapperxml,如下:

执行SQL:

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

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

配置动态数据源

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

优势

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

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

劣势

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

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

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

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

约定

建议

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

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

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

快速开始

加入依赖:

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

使用 @DS 切换数据源。

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

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

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

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

或者在类上排除:

然后更换properties配置信息:

本篇代码案例地址:

>

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

1首先在pom文件引入dynamic-datasource-spring-boot-starter

2applicationyml配置文件内容如下:

上面的配置中从dynamic开始是有关多数据源的配置,primary用来配置主数据源也叫默认数据源,它的默认值是master,因此,如果不指定primary的话一定要有名为master的数据源。strict 是用来配置是否启用严格 模式,如果为true表示启用,此时如果没有匹配的数据源会抛出异常,如果为false则会使用默认数据源。datasource下面就是配置多数据源的信息了。

后面的mybatis-plus配置我主要是用来说明集成这个不会对mybatis-plus对配置产生影响,该怎么用mybatis-plus就继续怎么用。

3使用@DS("要切换的数据源"),上面配置的test可以使用@DS("test")切换数据源

1注解添加在daomapper上无效

2注解添加到interface Service类上无效

3注解添加到interface Service方法上无效

那么,此注解应该如何使用呢?

添加@DS注解到实现类或者实现类的方法上才可以

当注解添加到类上,意味着此类里的方法都使用此数据源;

当注解添加到方法上时,意味着此方法上使用的数据源优先级高于其他一切配置

常见问题:

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

删除 *** 作多数据源的方法或者类、接口 上的 注解 @Transactional() 即可。

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

3数据源名称最好不要包含下滑线,下滑线的数据源切换不了

拓展-传播机制

java mybatisplus是什么,让我们一起了解一下?

MyBatis-Plus(简称MP)是一个MyBatis的增强工具,提供很多实用的插件。在Mybatis的基础上,只做增强不做改变,为简化我们开发,提高工作效率而生。

MyBatis-Plus的有些什么特性?

侵入:MyBatis-Plus是在MyBatis的基础上增强的,而没有做任何的改变,所以在项目中引入MyBatis Plus 不会对你的现在的MyBatis构架有任何的影响。

依赖少:引入MyBatis-Plus要导入什么包呢?仅仅依赖MyBatis与MyBatis-Spring就可以了。

损耗小:启动之后,会自动注入基本的CRUD,性能基本无消耗,直接面向对象 *** 作。

支持热加载:Mapper对应的XML支持热加载,对于简单的CRUD *** 作,甚至可以无XML启动。

支持代码生成:采用代码或Maven插件可快速生成Mapper、Model、Service、Controller层代码,支持模板引擎,更 提供了超多的自定义配置让你使用。

实战 *** 作:新建springboot项目,添加依赖至pomxml。     orgspringframeworkboot    spring-boot-starter-parent    226RELEASE  orgspringframeworkboot            spring-boot-starter                              orgspringframeworkboot            spring-boot-starter-test              test                                orgprojectlombok              lombok              true                              combaomidou              mybatis-plus-boot-starter              331tmp                              mysql              mysql-connector-java            5126

1、表数据库设置自增

2、mybatis-plus 的全局配置设置 idType = auto 的策略、可以参考官方网站 >

AbstractWrapper: 用于查询条件封装,生成sql的where条件

AbstractLambdaWrapper: Lambda语法使用Wrapper统一处理解析lambda获取column

QueryWrapper: Entity 对象封装 *** 作类,不是用lambda

UpdateWrapper: Update条件封装,用于Entity对象更新 *** 作

以上就是关于SpringBoot整合MyBatisPlus配置动态数据源全部的内容,包括:SpringBoot整合MyBatisPlus配置动态数据源、MyBatis-Plus中如何使用ResultMap、MyBatis-Plus 集成动态多数据源等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9515222.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-29
下一篇2023-04-29

发表评论

登录后才能评论

评论列表(0条)

    保存