當(dāng)前位置:
首頁(yè) >
springboot简易集成mybatisPlus+多数据源
發(fā)布時(shí)間:2025/3/21
36
豆豆
生活随笔
收集整理的這篇文章主要介紹了
springboot简易集成mybatisPlus+多数据源
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
該項(xiàng)目主要實(shí)現(xiàn)mybatisplus、多數(shù)據(jù)源、lombok、druid的集成
主要參考?https://mp.baomidou.com/guide/quick-start.html
項(xiàng)目地址:https://github.com/Blankwhiter/mybatisplus-springboot?release1.0
項(xiàng)目結(jié)構(gòu):
一、創(chuàng)建表以及測(cè)試數(shù)據(jù)
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');- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
二、引入項(xiàng)目依賴(lài),加入配置,修改啟動(dòng)類(lèi),編寫(xiě)實(shí)體類(lèi)和mapper對(duì)象(讀者可以根據(jù)自動(dòng)生成工具生成這塊代碼)
1.引入依賴(lài)
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.編寫(xiě)配置
application.yml
spring:autoconfigure:exclude: com.alibaba.druid.spring.boot.autoconfigure.DruidDataSourceAutoConfigure # 為了某些版本的springboot @SpringBootApplication(exclude= {DataSourceAutoConfiguration.class}) 無(wú)法生效datasource:dynamic:primary: master #設(shè)置默認(rèn)的數(shù)據(jù)源或者數(shù)據(jù)源組,默認(rèn)值即為master,如果讀者只是單數(shù)據(jù)源只需要注釋掉slave相關(guān)配置即可,這里為了方便演示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 需要填上時(shí)區(qū)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 需要填上時(shí)區(qū)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#實(shí)體掃描,多個(gè)package用逗號(hào)或者分號(hào)分隔typeAliasesPackage: com.example.mybatisplus.entitycheck-config-location: trueconfiguration:#是否開(kāi)啟自動(dòng)駝峰命名規(guī)則(camel case)映射map-underscore-to-camel-case: true#全局地開(kāi)啟或關(guān)閉配置文件中的所有映射器已經(jīng)配置的任何緩存cache-enabled: falsecall-setters-on-nulls: true#配置JdbcTypeForNull, oracle數(shù)據(jù)庫(kù)必須配置jdbc-type-for-null: 'null'#MyBatis 自動(dòng)映射時(shí)未知列或未知屬性處理策略 NONE:不做任何處理 (默認(rèn)值), WARNING:以日志的形式打印相關(guān)警告信息, FAILING:當(dāng)作映射失敗處理,并拋出異常和詳細(xì)信息auto-mapping-unknown-column-behavior: warningglobal-config:banner: falsedb-config:#主鍵類(lèi)型 0:"數(shù)據(jù)庫(kù)ID自增", 1:"未設(shè)置主鍵類(lèi)型",2:"用戶輸入ID (該類(lèi)型可以通過(guò)自己注冊(cè)自動(dòng)填充插件進(jìn)行填充)", 3:"全局唯一ID (idWorker), 4:全局唯一ID (UUID), 5:字符串全局唯一ID (idWorker 的字符串表示)";id-type: UUID#字段驗(yàn)證策略 IGNORED:"忽略判斷", NOT_NULL:"非NULL判斷", NOT_EMPTY:"非空判斷", DEFAULT 默認(rèn)的,一般只用于注解里(1. 在全局里代表 NOT_NULL,2. 在注解里代表 跟隨全局)field-strategy: NOT_EMPTY#數(shù)據(jù)庫(kù)大寫(xiě)下劃線轉(zhuǎn)換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.修改啟動(dòng)類(lèi)
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 默認(rèn)的數(shù)據(jù)源配置 @MapperScan("com.example.mybatisplus.mapper") //掃描mapper的包,或者讀者可以在對(duì)應(yīng)的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.編寫(xiě)實(shí)體
4.1?user.java
import lombok.Data;/*** user 實(shí)體類(lèi)*/ @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
注:讀者請(qǐng)自行在開(kāi)發(fā)工具安裝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") //這里是配置數(shù)據(jù)源注解,默認(rèn)是master public interface UserMapper extends BaseMapper<User> { }- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
三、編寫(xiě)測(cè)試用例
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;/*** 簡(jiǎn)單的測(cè)試增刪改查*/ @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
本文側(cè)重點(diǎn)于集成,更多功能移步至官網(wǎng)。
總結(jié)
以上是生活随笔為你收集整理的springboot简易集成mybatisPlus+多数据源的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: tensorflow之过拟合问题实战
- 下一篇: 孙正义看未来30年:投资趋势,永远不会错