包含springboot+mybatis的词条
本篇文章给大家谈谈springboot+mybatis,以及对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。
本文目录一览:
- 1、SpringBoot使用Mybatisamp;Mybatis-plus文件映射配置
- 2、SpringBoot整合MyBatisPlus配置动态数据源
- 3、Spring Boot(十一):MyBatis插件之MyBatis-Plus
SpringBoot使用Mybatisamp;Mybatis-plus文件映射配置
简介 :Springboot使用MybatisMybatis-plus 两者文件映射配置略有不同,之前我用的是Mybatis,但公司用Mybatis-plus;自己新建了一个Springboot项目,代码运行时一直报错not found not found,明明配置了mybatis相关信息的扫描路径,激袜毁但是就是好宏not found;检查修改了很多地方但都是无用功,最终发现是Plus惹的祸。
1、使用Mybatis
yml文件配置的mapper映射及相关信息格式:
2、使用Mybatis-Plus
yml文件配置的mapper映射及相关明备信息格式:
3、Others
加上 @Slf4j 注解后,仍然不能用log直接支配日志,因为没有安装Lombok插件。
加上 @Data 注解后,仍然不能使用getter/setter,因为没有安装Lombok插件。
在类上加注解@AllArgsConstructor 注解可以代替所有@Autowired 注解,就不用在一个类中引入多个@Autowired。
下载前端代码后需要在控制台运行:npm install,下载前端工程后在控制台npm install 相当于后端的下载jar包,目录级别还不能乱放,按照git工程代码格式,不能新建目录文件,否则资源下不来。
SpringBoot整合MyBatisPlus配置动态数据源
MybatisPlus特性
快速开始
初始化测试数据表:
父工程依赖
该工程用于依赖管理,pom如下:
创建MyBaitsPlus工程
依赖如下:
properties配置
在这里配置数据库连接,以及数据连接池与mybatisplus的配置等
常规增删改查实答者轮现
创建实体类:
该lombok插件省去getset方法。
创建UserMapper接口,并且实现BaseMapperUser这里我们指定实体类为user可直接使用接口中的方法。
UserMapper.xml,如下:
执行SQL:
在SpringBoot中使用MybatisPlus分页需要注入Bean,并且在启动类上使用@MapperScan("com.simple.spring.boot.mapper")扫描mapper文件路径如下:
使用MyBatisPlus可以为我们减少很多很多的代码,不过需要编写实体类,有失必有得。
配置动态数据源
dynamic-datasource-spring-boot-starter 是一个基于springboot的快速集成多数据源的启动器。
优势
网上关于动态数据源的切换的文档有很多,核心只有两种。
如果你的数据源较少,场景不复杂,选择以上任意一种都可以。如果你需要更多特性,请尝试本动态数据源。
劣势
不能使用多数据源事务(同一个数据源下能使用事务),网上其他方案也都不能提供。
如果你需要使用到分布式事务,那么你的架构应该到了微服务化的时候了。
如果呼声强烈,项目达到800 star,作者考虑集成分布式事务。
PS: 如果您只是几个数据库但是有强烈的需求分布式事务,建议还是使用传统方式自己构建多套环境集成atomic这类,网上百度很多。
约定
建议
强烈建议在 主从模式 下遵循普遍的规则,以便他人能更轻易理解你的代码。
主数据库 建议 只执行 INSERT UPDATE DELETE 操作。
从数据库 建议 只执行 SELECT 操作。
快速开始
加清信入依赖:
注释掉原来的数据库配置,加入:
使用 @DS 切换数据源。
@DS 可以注解在方法上和类上, 同时存在方法注解优先于类上注解 。
注解在service实现或mapper接口方法上,但强烈不建议同时在service和mapper注解。 (可能会有问题)
如果不加入主键则使用默认数据源。
DruidDataSourceAutoConfigure会注入一个DataSourceWrapper,其会在原生的spring.datasource下找url,username,password等。而我们动态数据源的配置路径是变化的,所以需要排除:
或者在类上排除:
然后更换properties配置信息:
本篇代码案例地址:嫌笑
作者:SimpleWu
出处:
[img]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)一般业务逻辑处理在service层,这里为了方便,直接在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+mybatis和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。