
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 集成动态多数据源等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)