springboot简易集成mybatisPlus+多数据源
该项目主要实现mybatisplus、多数据源、lombok、druid的集成
主要参考 https://mp.baomidou.com/guide/quick-start.html
项目地址:https://github.com/Blankwhiter/mybatisplus-springboot release1.0
项目结构:
一、创建表以及测试数据
CREATE TABLE user
(id VARCHAR(32) NOT NULL COMMENT '主键ID',name VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',age INT(11) NULL DEFAULT NULL COMMENT '年龄',email VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',PRIMARY KEY (id)
);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');
二、引入项目依赖,加入配置,修改启动类,编写实体类和mapper对象(读者可以根据自动生成工具生成这块代码)
1.引入依赖
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.4.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.example</groupId><artifactId>mybatisplus-springboot</artifactId><version>0.0.1-SNAPSHOT</version><name>mybatisplus-springboot</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version><mysql.version>6.0.6</mysql.version><mybatisplus.boot.version>3.1.0</mybatisplus.boot.version><druid.version>1.1.10</druid.version><dynamic.datasource.boot.version>2.5.4</dynamic.datasource.boot.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>${mysql.version}</version></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>${mybatisplus.boot.version}</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>${druid.version}</version></dependency><dependency><groupId>com.baomidou</groupId><artifactId>dynamic-datasource-spring-boot-starter</artifactId><version>${dynamic.datasource.boot.version}</version></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
2.编写配置
application.yml
spring:autoconfigure:exclude: com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 为了某些版本的springboot @SpringBootApplication(exclude= {DataSourceAutoConfiguration.class}) 无法生效datasource:dynamic:primary: master #设置默认的数据源或者数据源组,默认值即为master,如果读者只是单数据源只需要注释掉slave相关配置即可,这里为了方便演示master与slave保持相同datasource:master:url: jdbc:mysql://localhost:3306/test?serverTimezone=Hongkong&allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false # serverTimezone=Hongkong 需要填上时区username: rootpassword: 111111driverClassName: com.mysql.cj.jdbc.Driverslave:url: jdbc:mysql://localhost:3306/test?serverTimezone=Hongkong&allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&useSSL=false # serverTimezone=Hongkong 需要填上时区username: rootpassword: 111111driverClassName: com.mysql.cj.jdbc.Driverinitial-size: 10 # 以下是连接池配置max-active: 100min-idle: 10max-wait: 60000pool-prepared-statements: truemax-pool-prepared-statement-per-connection-size: 20time-between-eviction-runs-millis: 60000min-evictable-idle-time-millis: 300000#validation-query: SELECT 1test-while-idle: truetest-on-borrow: falsetest-on-return: falsestat-view-servlet:enabled: trueurl-pattern: /druid/*login-username: druidlogin-password: 123456filter:stat:log-slow-sql: trueslow-sql-millis: 1000merge-sql: falsewall:config:multi-statement-allow: true#mybatis plus
mybatis-plus:mapper-locations: classpath:mapper/**/*.xml#实体扫描,多个package用逗号或者分号分隔typeAliasesPackage: com.example.mybatisplus.entitycheck-config-location: trueconfiguration:#是否开启自动驼峰命名规则(camel case)映射map-underscore-to-camel-case: true#全局地开启或关闭配置文件中的所有映射器已经配置的任何缓存cache-enabled: falsecall-setters-on-nulls: true#配置JdbcTypeForNull, oracle数据库必须配置jdbc-type-for-null: 'null'#MyBatis 自动映射时未知列或未知属性处理策略 NONE:不做任何处理 (默认值), WARNING:以日志的形式打印相关警告信息, FAILING:当作映射失败处理,并抛出异常和详细信息auto-mapping-unknown-column-behavior: warningglobal-config:banner: falsedb-config:#主键类型 0:"数据库ID自增", 1:"未设置主键类型",2:"用户输入ID (该类型可以通过自己注册自动填充插件进行填充)", 3:"全局唯一ID (idWorker), 4:全局唯一ID (UUID), 5:字符串全局唯一ID (idWorker 的字符串表示)";id-type: UUID#字段验证策略 IGNORED:"忽略判断", NOT_NULL:"非NULL判断", NOT_EMPTY:"非空判断", DEFAULT 默认的,一般只用于注解里(1. 在全局里代表 NOT_NULL,2. 在注解里代表 跟随全局)field-strategy: NOT_EMPTY#数据库大写下划线转换capital-mode: true#逻辑删除值logic-delete-value: 0#逻辑未删除值logic-not-delete-value: 1server:port: 7000
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
3.修改启动类
MybatisplusSpringbootApplication.java
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;@SpringBootApplication(exclude= {DataSourceAutoConfiguration.class}) //去掉springboot 默认的数据源配置
@MapperScan("com.example.mybatisplus.mapper") //扫描mapper的包,或者读者可以在对应的mapper上加上@Mapper的注解
public class MybatisplusSpringbootApplication {public static void main(String[] args) {SpringApplication.run(MybatisplusSpringbootApplication.class, args);}}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
4.编写实体
4.1 user.java
import lombok.Data;/*** user 实体类*/
@Data
public class User {private String id;private String name;private Integer age;private String email;
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
注:读者请自行在开发工具安装lombok插件,或者去掉@data注解换成setter getter方法即可
4.2 UserMapper.java
import com.baomidou.dynamic.datasource.annotation.DS;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.mybatisplus.entity.User;/*** 用户mapper*/
@DS("slave") //这里是配置数据源注解,默认是master
public interface UserMapper extends BaseMapper<User> {
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
三、编写测试用例
import com.example.mybatisplus.entity.User;
import com.example.mybatisplus.mapper.UserMapper;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;import java.util.List;/*** 简单的测试增删改查*/
@RunWith(SpringRunner.class)
@SpringBootTest
public class MybatisplusSpringbootApplicationTests {@Autowiredprivate UserMapper userMapper;@Testpublic void addUser() {User user = new User();user.setAge(200);user.setEmail("belonghuang@outlook.com");user.setName("belongHuang");userMapper.insert(user);}@Testpublic void updateUser() {User user = userMapper.selectById(1);user.setAge(300);int i = userMapper.updateById(user);if (i>0) {System.out.println("修改成功");}else {System.out.println("修改失败");}}@Testpublic void deleteUser() {int i = userMapper.deleteById(1);if (i>0) {System.out.println("删除成功");}else {System.out.println("删除失败");}}@Testpublic void selectUser() {List<User> users = userMapper.selectList(null);users.stream().map(User::getName).forEach(System.out::println);//打印出所用用户名字}}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
springboot简易集成mybatisPlus+多数据源相关推荐
- Sharding-Jdbc分库分表集成Mybatis-Plus+多数据源管理
为什么要用sharding-jdbc进行分库分表 1.为什么要使用分库分表: 分表前提:当单表数据量太大,会极大的影响sql的执行性能,这时sql会跑的很慢.当单表到达几百万的时候,性能就会有所下降. ...
- spring boot 2.1学习笔记【八】SpringBoot 2 集成 mysql多数据源, MySQL多数据源事务
springboot系列学习笔记全部文章请移步值博主专栏**: spring boot 2.X/spring cloud Greenwich. 由于是一系列文章,所以后面的文章可能会使用到前面文章的项 ...
- 【SpringBoot深入浅出系列】SpringBoot之集成MyBatis-Plus
目录 一.MyBatis-Plus 是什么? 二.创建项目集成 MyBatis-Plus 1.项目说明 2.创建 Spring Initializr 项目 mybatisplus (1).添加依赖 ( ...
- SpringBoot之集成MybatisPlus
正式开始研究springboot的数据库集成 *******************第一个概论druid******************* Druid是一个数据库连接池, 添加依赖: <de ...
- SpringBoot集成MyBatis-Plus代码生成器(Dao)
1.说明 本文基于SpringBoot集成MyBatis-Plus代码生成器, 把原来生成Entity.Mapper.Mapper XML.Service.Controller等各个模块的代码, 修改 ...
- SpringBoot集成MyBatis-Plus代码生成器
1.说明 本文详细介绍Spring Boot集成MyBatis-Plus代码生成器的方法. 基于一个创建好的Spring Boot工程, 执行MyBatis-Plus提供的AutoGenerator代 ...
- SpringBoot集成MyBatisPlus
概述 SpringBoot集成MyBatisPlus集成Shiro 可以快速开发 详细 代码下载:http://www.demodashi.com/demo/12099.html 项目结构 wstro ...
- SpringBoot集成MyBatis-Plus自定义SQL
1.说明 本文介绍Spring Boot集成MyBatis-Plus框架后, 基于已经创建好的Spring Boot工程, 添加自定义的SQL实现复杂查询等操作. 自定义SQL主要有两种方式, 一种是 ...
- SpringBoot集成MyBatis-Plus框架
1.说明 本文介绍Spring Boot集成MyBatis-Plus框架, 重点介绍需要注意的地方, 是SpringBoot集成MyBatis-Plus框架详细方法 这篇文章的脱水版, 主要是三个步骤 ...
最新文章
- 一个基于cocos2d-x 3.0和Box2d的demo小程序
- c语言规范标准中英文,C语言中英文翻译资料.doc
- java jvm 查看内存_JVM内存状况查看方法和分析工具(下)
- s:radio 赋值取值和添加事件
- 图的更多相关算法-2(最小生成树)
- Spring AOP原理分析(三)-- AnnotationAwareAspectJAutoProxyCreator#initBeanFactory()源码
- 梯度下降的线性回归用python_学习笔记:使用python 实现线性回归里的梯度下降...
- wps office有计算机应用吗,wps office
- 无线技术网络导论--期末复习指导
- html横向滚动字幕代码,js文字横向滚动特效
- 硬件保护和软件保护_什么是硬件保护?
- 004@ kernel 的配置和编译总结 分析2
- db mysql error_list
- codeforces 1567 E. Non-Decreasing Dilemma
- Attributed Graph Clustering: A Deep Attentional Embedding Approach,IJCAI2019
- 让 GitHub 上这几个小游戏帮你找回童真
- 几张图片生成3D模型?距离真正的AI建模还有多远?
- 大数据处理算法--Bloom Filter布隆过滤
- Python 深度学习 Class 2:神经网络的数学基础
- word2016 明明设置了默认粘贴为“仅保留文本”,可是每次粘贴的时候还是带源格式怎么办?
热门文章
- 文本编辑器实现关于对话框的功能
- hibenate5.1配置mysql_hibernate5.2的基本配置方法(详解)
- linux 管道使用方法,Linux 管道命令
- linux文件目录操作实验报告,Linux操作系统实验4文件和目录操作
- iis mysql php 附件上传大小_修改上传附件2M大小限制的方法/php+iis上传附件默认大小修改方法...
- log4.properties文件【笔记自用】
- Linux下CMake简明教程(三)同一目录下多个源文件
- pyspark基础教程
- Leetcode 102.二叉树的层序遍历 (每日一题 20210628)
- anaconda下tensorflow安装遇到的问题记录及解决办法