c/c++开发分享使用@DS轻松解决动态数据源的问题

@ds解决动态数据源问题动态切换数据源,无非是继承org.springframework.jdbc.datasource.lookup.abstractroutingdatasource这个类,重写d

@ds解决动态数据源问题

动态切换数据源,无非是继承org.springframework.jdbc.datasource.lookup.abstractroutingdatasource这个类,重写determinecurrentlookupkey()这个方法,动态变换数据源的key值,有人已经将详细代码封装到框架中,我们只需要使用它的注解@ds就好。

引入maven

<!-- https://mvnrepository.com/artifact/com.baomidou/dynamic-datasource-spring-boot-starter -->          <dependency>              <groupid>com.baomidou</groupid>              <artifactid>dynamic-datasource-spring-boot-starter</artifactid>              <version>3.2.1</version>          </dependency>

修改application.yml

参考的是官网的例子

spring:    datasource:      dynamic:        primary: master #设置默认的数据源或者数据源组,默认值即为master        strict: false #设置严格模式,默认false不启动. 启动后在未匹配到指定数据源时候会抛出异常,不启动则使用默认数据源.        datasource:          master:            url: jdbc:mysql://xx.xx.xx.xx:3306/dynamic            username: root            password: 123456            driver-class-name: com.mysql.jdbc.driver # 3.2.0开始支持spi可省略此配置          slave_1:            url: jdbc:mysql://xx.xx.xx.xx:3307/dynamic            username: root            password: 123456            driver-class-name: com.mysql.jdbc.driver          slave_2:            url: enc(xxxxx) # 内置加密,使用请查看详细文档            username: enc(xxxxx)            password: enc(xxxxx)            driver-class-name: com.mysql.jdbc.driver            schema: db/schema.sql # 配置则生效,自动初始化表结构            data: db/data.sql # 配置则生效,自动初始化数据            continue-on-error: true # 默认true,初始化失败是否继续            separator: ";" # sql默认分号分隔符                     #......省略         #以上会配置一个默认库master,一个组slave下有两个子库slave_1,slave_2

这是我自己的:

spring:    datasource:      dynamic:        primary: master #设置默认的数据源或者数据源组,默认值即为master #设置严格模式,默认false不启动. 启动后在未匹配到指定数据源时候会抛出异常,不启动则使用默认数据源.        datasource:          master:            url: jdbc:sqlserver://127.0.0.1:1433;databasename=balabala            username: sa            password: 123456sa            driver-class-name: com.microsoft.sqlserver.jdbc.sqlserverdriver          sub:            url: jdbc:mysql://127.0.0.1:3307/balabala?useunicode=true&characterencoding=utf-8&servertimezone=asia/shanghai            username: sa            password: 123456sa            driver-class-name: com.mysql.cj.jdbc.driver

在需要使用非默认数据库的dao层的方法上加上注解@ds(“数据库名”)即可

@ds("sub")  int selectbusiness(@param("starttime") string starttime,                     @param("endtime") string endtime,                     @param("businesstype") string businesstype);

@ds注解说明

写法:

@ds(value = "数据源名称")  datasource:   数据源名臣

注解在类上或方法上来切换数据源

gradle:

com.baomidou:dynamic-datasource-spring-boot-starter:2.5.3

打开一个线程得方法

new thread(() -> {      方法内容-------------------------------------  }).start();

以上为个人经验,希望能给大家一个参考,也希望大家多多支持<猴子技术宅>。

需要了解更多c/c++开发分享使用@DS轻松解决动态数据源的问题,都可以关注C/C++技术分享栏目—猴子技术宅(www.ssfiction.com)

本文来自网络收集,不代表猴子技术宅立场,如涉及侵权请点击右边联系管理员删除。

如若转载,请注明出处:https://www.ssfiction.com/c-cyuyankaifa/1240356.html

(0)
上一篇 4天前
下一篇 4天前

精彩推荐

发表回复

您的电子邮箱地址不会被公开。