该项目主要实现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);//打印出所用用户名字}}

本文侧重点于集成,更多功能移步至官网。

springboot简易集成mybatisPlus+多数据源相关推荐

  1. Sharding-Jdbc分库分表集成Mybatis-Plus+多数据源管理

    为什么要用sharding-jdbc进行分库分表 1.为什么要使用分库分表: 分表前提:当单表数据量太大,会极大的影响sql的执行性能,这时sql会跑的很慢.当单表到达几百万的时候,性能就会有所下降. ...

  2. spring boot 2.1学习笔记【八】SpringBoot 2 集成 mysql多数据源, MySQL多数据源事务

    springboot系列学习笔记全部文章请移步值博主专栏**: spring boot 2.X/spring cloud Greenwich. 由于是一系列文章,所以后面的文章可能会使用到前面文章的项 ...

  3. 【SpringBoot深入浅出系列】SpringBoot之集成MyBatis-Plus

    目录 一.MyBatis-Plus 是什么? 二.创建项目集成 MyBatis-Plus 1.项目说明 2.创建 Spring Initializr 项目 mybatisplus (1).添加依赖 ( ...

  4. SpringBoot之集成MybatisPlus

    正式开始研究springboot的数据库集成 *******************第一个概论druid******************* Druid是一个数据库连接池, 添加依赖: <de ...

  5. SpringBoot集成MyBatis-Plus代码生成器(Dao)

    1.说明 本文基于SpringBoot集成MyBatis-Plus代码生成器, 把原来生成Entity.Mapper.Mapper XML.Service.Controller等各个模块的代码, 修改 ...

  6. SpringBoot集成MyBatis-Plus代码生成器

    1.说明 本文详细介绍Spring Boot集成MyBatis-Plus代码生成器的方法. 基于一个创建好的Spring Boot工程, 执行MyBatis-Plus提供的AutoGenerator代 ...

  7. SpringBoot集成MyBatisPlus

    概述 SpringBoot集成MyBatisPlus集成Shiro 可以快速开发 详细 代码下载:http://www.demodashi.com/demo/12099.html 项目结构 wstro ...

  8. SpringBoot集成MyBatis-Plus自定义SQL

    1.说明 本文介绍Spring Boot集成MyBatis-Plus框架后, 基于已经创建好的Spring Boot工程, 添加自定义的SQL实现复杂查询等操作. 自定义SQL主要有两种方式, 一种是 ...

  9. SpringBoot集成MyBatis-Plus框架

    1.说明 本文介绍Spring Boot集成MyBatis-Plus框架, 重点介绍需要注意的地方, 是SpringBoot集成MyBatis-Plus框架详细方法 这篇文章的脱水版, 主要是三个步骤 ...

最新文章

  1. 一个基于cocos2d-x 3.0和Box2d的demo小程序
  2. c语言规范标准中英文,C语言中英文翻译资料.doc
  3. java jvm 查看内存_JVM内存状况查看方法和分析工具(下)
  4. s:radio 赋值取值和添加事件
  5. 图的更多相关算法-2(最小生成树)
  6. Spring AOP原理分析(三)-- AnnotationAwareAspectJAutoProxyCreator#initBeanFactory()源码
  7. 梯度下降的线性回归用python_学习笔记:使用python 实现线性回归里的梯度下降...
  8. wps office有计算机应用吗,wps office
  9. 无线技术网络导论--期末复习指导
  10. html横向滚动字幕代码,js文字横向滚动特效
  11. 硬件保护和软件保护_什么是硬件保护?
  12. 004@ kernel 的配置和编译总结 分析2
  13. db mysql error_list
  14. codeforces 1567 E. Non-Decreasing Dilemma
  15. Attributed Graph Clustering: A Deep Attentional Embedding Approach,IJCAI2019
  16. 让 GitHub 上这几个小游戏帮你找回童真
  17. 几张图片生成3D模型?距离真正的AI建模还有多远?
  18. 大数据处理算法--Bloom Filter布隆过滤
  19. Python 深度学习 Class 2:神经网络的数学基础
  20. word2016 明明设置了默认粘贴为“仅保留文本”,可是每次粘贴的时候还是带源格式怎么办?

热门文章

  1. 文本编辑器实现关于对话框的功能
  2. hibenate5.1配置mysql_hibernate5.2的基本配置方法(详解)
  3. linux 管道使用方法,Linux 管道命令
  4. linux文件目录操作实验报告,Linux操作系统实验4文件和目录操作
  5. iis mysql php 附件上传大小_修改上传附件2M大小限制的方法/php+iis上传附件默认大小修改方法...
  6. log4.properties文件【笔记自用】
  7. Linux下CMake简明教程(三)同一目录下多个源文件
  8. pyspark基础教程
  9. Leetcode 102.二叉树的层序遍历 (每日一题 20210628)
  10. anaconda下tensorflow安装遇到的问题记录及解决办法