欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

springboot集成mybatis?plus和dynamic-datasource注意事項(xiàng)說明

 更新時間:2022年01月07日 14:41:16   作者:_翚_  
這篇文章主要介紹了springboot集成mybatis?plus和dynamic-datasource注意事項(xiàng)說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

springboot集成mybatis plus和dynamic-datasource注意事項(xiàng)

環(huán)境

  • spring-boot-starter-parent 1.5.2.RELEASE
  • mybatis-plus-boot-starter 2.x
  • dynamic-datasource-spring-boot-starter 2.5.0
  • druid-spring-boot-starter 1.1.10

注意事項(xiàng)

@SpringBootApplication(exclude = DruidDataSourceAutoConfigure.class)

dynamic所有版本默認(rèn)啟用stat和wall過濾器(默認(rèn)不支持批量執(zhí)行sql, 并且有些低版本無法自定義)

開啟批量執(zhí)行sql的方法

# 方法1:升級版本, 如2.5.0
spring:
? datasource:
? ? dynamic:
? ? ? druid:?
? ? ? ? wall:
? ? ? ? ? noneBaseStatementAllow: true
? ? ? ? ? multiStatementAllow: true
# 方法2:移除wall過濾器
spring:
? datasource:
? ? dynamic:
? ? ? druid:?
? ? ? ? filters: stat

現(xiàn)有項(xiàng)目集成mybatis plus時,應(yīng)指定另外的枚舉包,否則會出問題

mybatis-plus:
? type-enums-package: com.zxkj.demo.enums.mp

springboot mybatis plus多數(shù)據(jù)源配置整合dynamic-datasource

pro文件引入依賴

? ? ? ?<dependency>
? ? ? ? ? ? <groupId>mysql</groupId>
? ? ? ? ? ? <artifactId>mysql-connector-java</artifactId>
? ? ? ? ? ? <scope>runtime</scope>
? ? ? ? </dependency>
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>com.alibaba</groupId>
? ? ? ? ? ? <artifactId>druid-spring-boot-starter</artifactId>
? ? ? ? ? ? <version>1.2.6</version>
? ? ? ? </dependency>
? ? ? ? <!--mybatis-plus-->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>com.baomidou</groupId>
? ? ? ? ? ? <artifactId>mybatis-plus-boot-starter</artifactId>
? ? ? ? ? ? <version>3.1.2</version>
? ? ? ? </dependency>
? ? ? ? <!--主從配置依賴-->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>com.baomidou</groupId>
? ? ? ? ? ? <artifactId>dynamic-datasource-spring-boot-starter</artifactId>
? ? ? ? ? ? <version>2.5.6</version>
? ? ? ? </dependency>
? ? ? ? <!--lombok用來簡化實(shí)體類:需要安裝lombok插件-->
? ? ? ? <dependency>
? ? ? ? ? ? <groupId>org.projectlombok</groupId>
? ? ? ? ? ? <artifactId>lombok</artifactId>
? ? ? ? ? ? <version>1.18.20</version>
? ? ? ? </dependency>

application.yml配置

spring:
? datasource:
? ? dynamic:
? ? ? primary: master #設(shè)置默認(rèn)數(shù)據(jù)源或數(shù)據(jù)源組,master默認(rèn)值(數(shù)據(jù)源名稱可以隨意起名,沒有固定值,eg:db1,db2)
? ? ? strict: false #設(shè)置嚴(yán)格模式,默認(rèn)false不啟動. 啟動后在未匹配到指定數(shù)據(jù)源時候回拋出異常,不啟動會使用默認(rèn)數(shù)據(jù)源.
? ? ? datasource:
? ? ? ? master:
? ? ? ? ? driver-class-name: com.mysql.cj.jdbc.Driver
? ? ? ? ? url: jdbc:mysql://192.168.3.220:3306/mchouse_test1?useUnicode=true&characterEncoding=utf-8
? ? ? ? ? username: *****
? ? ? ? ? password: *****
? ? ? ? slave_1:
? ? ? ? ? driver-class-name: com.mysql.cj.jdbc.Driver
? ? ? ? ? url: jdbc:mysql://112.30.184.149:3306/net_trans_sup_hefei_edi?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
? ? ? ? ? username: *****
? ? ? ? ? password: *****
? ? ? ? slave_2:
? ? ? ? ? driver-class-name: com.mysql.cj.jdbc.Driver
? ? ? ? ? url: jdbc:mysql://120.55.168.100:33066/net_trans_sup_hefei_edi?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
? ? ? ? ? username: *****
? ? ? ? ? password: *****
mybatis-plus:
# ?configuration:
# ? ?log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #org.apache.ibatis.logging.slf4j.Slf4jImpl
? mapper-locations: classpath:mapper/*.xml #配置mybatis.xml文件路勁 classpath根路徑
? global-config:
? ? # 邏輯刪除配置
? ? db-config:
? ? ? # 刪除后
? ? ? logic-delete-value: 1
? ? ? # 刪除前
? ? ? logic-not-delete-value: 0

修改Application啟動類

@SpringBootApplication(exclude = {DruidDataSourceAutoConfigure.class})

這里要排除DruidDataSourceAutoConfigure ,因?yàn)镈ruidDataSourceAutoConfigure會注入一個DataSourceWrapper,其會在原生的spring.datasource下找url,username,password等。而我們動態(tài)數(shù)據(jù)源的配置路徑是變化的。

創(chuàng)建MybatisPlusConfig

@Configuration
@EnableTransactionManagement
@MapperScan("com.example.md5_demo.com.db.**.mapper")
public class MyBatisPlusConfig {
? ? /**
? ? ?* SQL 執(zhí)行性能分析插件
? ? ?* 開發(fā)環(huán)境使用,線上不推薦。 maxTime 指的是 sql 最大執(zhí)行時長
? ? ?*/
? ? @Bean
? ? @Profile({"dev","test"})// 設(shè)置 dev test 環(huán)境開啟
? ? public PerformanceInterceptor performanceInterceptor() {
? ? ? ? PerformanceInterceptor performanceInterceptor = new PerformanceInterceptor();
? ? ? ? performanceInterceptor.setMaxTime(100000);//ms,超過此處設(shè)置的ms則sql不執(zhí)行
? ? ? ? performanceInterceptor.setFormat(true);
? ? ? ? return performanceInterceptor;
? ? }
? ? /**
? ? ?* 邏輯刪除插件
? ? ?*/
? ? @Bean
? ? public ISqlInjector sqlInjector() {
? ? ? ? return new LogicSqlInjector();
? ? }
? ? /**
? ? ?* 分頁插件
? ? ?*/
? ? @Bean
? ? public PaginationInterceptor paginationInterceptor() {
? ? ? ? return new PaginationInterceptor();
? ? }
}

創(chuàng)建mapper接口

@Mapper
public interface DemoMapper extends BaseMapper<Demo> {
? ? List<Demo> getAllList();
? ? @DS("slave_2")
? ? List<Demo> getShopList();
}

測試類測試

@SpringBootTest
class Md5DemoApplicationTests {
? ? @Autowired
? ? private DemoMapper demoMapper;
? ? @Test
? ? void contextLoads() {
? ? ? ? List<Demo> list=demoMapper.getAllList();
? ? ? ? System.out.println(list);
? ? ? ? System.out.println("***************");
? ? ? ? List<Demo> shopList=demoMapper.getShopList();
? ? ? ? System.out.println(shopList);
? ? }
}

@DS優(yōu)先級:方法 > 類

@DS 可以注解在方法上和類上,同時存在方法注解優(yōu)先于類上注解,mapper或者service都可以添加,建議只在一個方法上添加即可。

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JVM內(nèi)存模型知識點(diǎn)總結(jié)

    JVM內(nèi)存模型知識點(diǎn)總結(jié)

    在本篇文章里小編給大家分享了關(guān)于JVM內(nèi)存模型的學(xué)習(xí)心得以及相關(guān)知識點(diǎn)總結(jié),有興趣的朋友們跟著學(xué)習(xí)下。
    2019-05-05
  • JAVA中 redisTemplate 和 jedis的配合使用操作

    JAVA中 redisTemplate 和 jedis的配合使用操作

    這篇文章主要介紹了JAVA中 redisTemplate 和 jedis的配合使用操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • JSONObject按put順序排放與輸出方式

    JSONObject按put順序排放與輸出方式

    這篇文章主要介紹了JSONObject按put順序排放與輸出方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • Redisson分布式閉鎖RCountDownLatch的使用詳細(xì)講解

    Redisson分布式閉鎖RCountDownLatch的使用詳細(xì)講解

    分布式鎖和我們java基礎(chǔ)中學(xué)習(xí)到的synchronized略有不同,synchronized中我們的鎖是個對象,當(dāng)前系統(tǒng)部署在不同的服務(wù)實(shí)例上,單純使用synchronized或者lock已經(jīng)無法滿足對庫存一致性的判斷。本次主要講解基于rediss實(shí)現(xiàn)的分布式鎖
    2023-02-02
  • java堆棧類使用實(shí)例(java中stack的使用方法)

    java堆棧類使用實(shí)例(java中stack的使用方法)

    java中stack的使用方法,堆棧是一種"后進(jìn)先出"(LIFO) 的數(shù)據(jù)結(jié)構(gòu), 只能在一端進(jìn)行插入(稱為"壓棧") 或刪除 (稱為"出棧")數(shù)據(jù)的操作,下面看示例吧
    2013-12-12
  • Java堆&優(yōu)先級隊(duì)列示例講解(下)

    Java堆&優(yōu)先級隊(duì)列示例講解(下)

    這篇文章主要通過示例詳細(xì)為大家介紹Java中的堆以及優(yōu)先級隊(duì)列,文中的示例代碼講解詳細(xì),對我們了解java有一定幫助,需要的可以參考一下
    2022-03-03
  • GC參考手冊二java中垃圾回收原理解析

    GC參考手冊二java中垃圾回收原理解析

    由于有個垃圾回收機(jī)制,java中的額對象不在有“作用域”的概念,只有對象的引用才有“作用域”。垃圾回收可以有效的防止內(nèi)存泄露,有效的使用空閑的內(nèi)存<BR>
    2022-01-01
  • 詳解java封裝返回結(jié)果與RestControllerAdvice注解

    詳解java封裝返回結(jié)果與RestControllerAdvice注解

    這篇文章主要為大家介紹了java封裝返回結(jié)果與RestControllerAdvice注解實(shí)例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • SpringDataJPA詳解增刪改查操作方法

    SpringDataJPA詳解增刪改查操作方法

    這篇文章主要介紹了SpringDataJpa增刪改查操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • IDEA中Spring項(xiàng)目的工程構(gòu)建

    IDEA中Spring項(xiàng)目的工程構(gòu)建

    這篇文章主要介紹了IDEA中Spring項(xiàng)目的工程構(gòu)建,Spring框架是輕量級的JavaEE框架,可以解決企業(yè)應(yīng)用開發(fā)的復(fù)雜性,有兩個核心部分:IOC和Aop,今天來學(xué)習(xí)如何構(gòu)建spring項(xiàng)目,需要的朋友可以參考下
    2023-05-05

最新評論