国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

SpringBoot+mybatis+pgsql多個數(shù)據(jù)源配置

這篇具有很好參考價值的文章主要介紹了SpringBoot+mybatis+pgsql多個數(shù)據(jù)源配置。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

一、配置文件

jdk環(huán)境:1.8 配置了雙數(shù)據(jù)源springboot+druid+pgsql,application.properties配置修改如下:

#當(dāng)前入庫主數(shù)據(jù)庫
spring.primary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.primary.datasource.driver-class-name=org.postgresql.Driver
spring.primary.datasource.url=jdbc:postgresql://localhost:5432/testdb
spring.primary.datasource.username=postgres
spring.primary.datasource.password=postgres
#
#從數(shù)據(jù)庫
spring.secondary.datasource.type=com.alibaba.druid.pool.DruidDataSource
spring.secondary.datasource.driver-class-name=org.postgresql.Driver
spring.secondary.datasource.url=jdbc:postgresql://localhost:5432/postgres
spring.secondary.datasource.username=postgres
spring.secondary.datasource.password=postgres

spring.datasource.druid.initial-size=5
spring.datasource.druid.min-idle=5
spring.datasource.druid.max-active=20

二、Java代碼配置新增

主數(shù)據(jù)庫注入

/**
 * @Author yang
 * @Date 2023/2/20 11:10
 * @Version 1.0
 */
import com.alibaba.druid.pool.DruidDataSource;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Primary;
import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;

import javax.sql.DataSource;

@Configuration
@MapperScan(basePackages = MasterDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "masterSqlSessionFactory")
public class MasterDataSourceConfig {
    // 精確到master目錄,以便跟其他數(shù)據(jù)源隔離
    static final String PACKAGE = "com.xx.dao.master";
    static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/master/*.xml";

    @Value("${spring.primary.datasource.url}")
    private String url;

    @Value("${spring.primary.datasource.username}")
    private String user;

    @Value("${spring.primary.datasource.password}")
    private String password;

    @Value("${spring.primary.datasource.driver-class-name}")
    private String driverClass;

    private SqlSessionFactory mSessionFactory;


    @Bean(name = "masterDataSource")
    @Primary
    public DataSource masterDataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driverClass);
        dataSource.setUrl(url);
        dataSource.setUsername(user);
        dataSource.setPassword(password);
        return dataSource;
    }

    @Bean(name = "masterTransactionManager")
    @Primary
    public DataSourceTransactionManager masterTransactionManager() {
        return new DataSourceTransactionManager(masterDataSource());
    }

    @Bean(name = "masterSqlSessionFactory")
    @Primary
    public SqlSessionFactory masterSqlSessionFactory(@Qualifier("masterDataSource") DataSource masterDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(masterDataSource);
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(MasterDataSourceConfig.MAPPER_LOCATION));
        //開啟駝峰
        sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
        this.mSessionFactory = sessionFactory.getObject();
        return sessionFactory.getObject();
    }

    /**
     * 獲取主庫 SessionFactory
     * @return
     */
    public SqlSessionFactory getMSessionFactory(){
        return mSessionFactory;
    }

}

從數(shù)據(jù)庫Java代碼:

/**
 * @Author yang
 * @Date 2023/2/20 11:52
 * @Version 1.0
 */
@Configuration
// 掃描 Mapper 接口并容器管理
@MapperScan(basePackages = SecondDataSourceConfig.PACKAGE, sqlSessionFactoryRef = "secondSqlSessionFactory")
public class SecondDataSourceConfig {
    //精確到第二個數(shù)據(jù)庫目錄,以便跟其他數(shù)據(jù)源隔離
    static final String PACKAGE = "com.xx.dao.second";
    static final String MAPPER_LOCATION = "classpath*:com/xx/mapper/second/*.xml";

    @Value("${spring.secondary.datasource.url}")
    private String url;

    @Value("${spring.secondary.datasource.username}")
    private String user;

    @Value("${spring.secondary.datasource.password}")
    private String password;

    @Value("${spring.secondary.datasource.driver-class-name}")
    private String driverClass;

    @Bean(name = "secondDataSource")
    public DataSource clusterDataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName(driverClass);
        dataSource.setUrl(url);
        dataSource.setUsername(user);
        dataSource.setPassword(password);
        return dataSource;
    }

    @Bean(name = "secondTransactionManager")
    public DataSourceTransactionManager clusterTransactionManager() {
        return new DataSourceTransactionManager(clusterDataSource());
    }

    @Bean(name = "secondSqlSessionFactory")
    public SqlSessionFactory clusterSqlSessionFactory(@Qualifier("secondDataSource") DataSource clusterDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(clusterDataSource);
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(SecondDataSourceConfig.MAPPER_LOCATION));
        //開啟駝峰
        sessionFactory.getObject().getConfiguration().setMapUnderscoreToCamelCase(true);
        return sessionFactory.getObject();
    }
}

三、mapper接口、mybatis/xml文件配置

? ? ?這里就就不一一貼代碼了,主要是接口對應(yīng)mybatis xml配置文件。項目文件接口如下:

SpringBoot+mybatis+pgsql多個數(shù)據(jù)源配置,java,JAVA架構(gòu),mybatis,spring boot,后端

創(chuàng)建成以上目錄就可以了,分別是dao接口、Java數(shù)據(jù)源配置、mybatis映射文件。

四、怎么使用

? ? ? 通過以上配置文件和代碼已經(jīng)對兩個數(shù)據(jù)源進行分割,直接正常使用訪問代碼即可,比如dao里面創(chuàng)建了testClass的操作

void insert(Test test);
void delete();

Controller層我們通過@Autowired注解 使用就可以了。

這里需要注意修改:

@MapperScan里面的basePackages

MAPPER_LOCATION變量的配置,這里主要是不同的數(shù)據(jù)源配置掃描不同的mybatis配置文件文章來源地址http://www.zghlxwxcb.cn/news/detail-682267.html

到了這里,關(guān)于SpringBoot+mybatis+pgsql多個數(shù)據(jù)源配置的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • springboot + (mysql/pgsql) + jpa 多數(shù)據(jù)源(不同類數(shù)據(jù)源)

    ?配置文件: datasourceconfig: 數(shù)據(jù)源一: 數(shù)據(jù)源二:

    2024年02月14日
    瀏覽(22)
  • SpringBoot結(jié)合MyBatis實現(xiàn)多數(shù)據(jù)源配置

    SpringBoot結(jié)合MyBatis實現(xiàn)多數(shù)據(jù)源配置

    SpringBoot框架實現(xiàn)多數(shù)據(jù)源操作,首先需要搭建Mybatis的運行環(huán)境。 由于是多數(shù)據(jù)源,也就是要有多個數(shù)據(jù)庫,所以,我們創(chuàng)建兩個測試數(shù)據(jù)庫,分別是:【sp-demo01】和【sp-demo02】,如下圖所示: 具體SQL代碼: 創(chuàng)建【sp-demo01】數(shù)據(jù)庫。 創(chuàng)建【sp-demo02】數(shù)據(jù)庫。 MyBatis框架中,

    2024年02月09日
    瀏覽(15)
  • Springboot 配置動態(tài)多數(shù)據(jù)源(Mybatis-plus)

    Springboot 配置動態(tài)多數(shù)據(jù)源(Mybatis-plus)

    前言:在項目中需要用到動態(tài)切換多數(shù)據(jù)源,查閱Mybatis-plus文檔得知可以通過@DS注解,但該方法主要針對不同內(nèi)容的數(shù)據(jù)源,而目前場景是相同內(nèi)容的數(shù)據(jù)庫需要在運行時根據(jù)請求頭動態(tài)切換,因此文檔方法不適用。 注意,不要使用dynamic-datasource-spring-boot-starter依賴包。 應(yīng)用

    2024年02月12日
    瀏覽(23)
  • grpc + springboot + mybatis-plus 動態(tài)配置數(shù)據(jù)源

    grpc + springboot + mybatis-plus 動態(tài)配置數(shù)據(jù)源

    前言 這是我在這個網(wǎng)站整理的筆記,關(guān)注我,接下來還會持續(xù)更新。 作者:神的孩子都在歌唱 1.1 項目初始化 項目初始化的時候會調(diào)用com.baomidou.dynamic.datasource.DynamicRoutingDataSource對象的addDataSource方法添加數(shù)據(jù)源,數(shù)據(jù)源存進dataSourceMap中。 1.2 接口請求時候 進行數(shù)據(jù)操作時,

    2024年02月09日
    瀏覽(30)
  • SpringBoot整合Mybatis-Plus、Druid配置多數(shù)據(jù)源

    SpringBoot整合Mybatis-Plus、Druid配置多數(shù)據(jù)源

    目錄 1.初始化項目 1.1.初始化工程 1.2.添加依賴 1.3.配置yml文件 1.4.Spring Boot 啟動類中添加?@MapperScan?注解,掃描 Mapper 文件夾 1.5.配置使用數(shù)據(jù)源 1.5.1.注解方式 1.5.2.基于AOP手動實現(xiàn)多數(shù)據(jù)源原生的方式 2.結(jié)果展示 Mybatis-Plus:簡介 | MyBatis-Plus (baomidou.com) 在正式開始之前,先初始

    2024年02月11日
    瀏覽(24)
  • Dynamic DataSource 多數(shù)據(jù)源配置【 Springboot + DataSource + MyBatis Plus + Druid】

    Dynamic DataSource 多數(shù)據(jù)源配置【 Springboot + DataSource + MyBatis Plus + Druid】

    MybatisPlus多數(shù)據(jù)源配置主要解決的是多數(shù)據(jù)庫連接和切換的問題。在一些大型應(yīng)用中,由于數(shù)據(jù)量的增長或者業(yè)務(wù)模塊的增多,可能需要訪問多個數(shù)據(jù)庫。這時,就需要配置多個數(shù)據(jù)源。 2.1.1、引用依賴 2.1.2、application.yml 配置 2.1.3、通用配置類 2.1.4、使用方式 這里便不過多的

    2024年02月03日
    瀏覽(32)
  • java_Springboot_Mybatis-Plus_自定義多數(shù)據(jù)源MybatisSqlSessionFactoryBean配置

    需要在服務(wù)中集成表結(jié)構(gòu)維護的功能,維護表結(jié)構(gòu)就需要使用具有執(zhí)行DDL腳本權(quán)限的賬號。 為了保證系統(tǒng)的安全性,考慮在工程中配置多個數(shù)據(jù)源引入不同權(quán)限賬號,高權(quán)限賬號只在特定邏輯中使用,其它默認(rèn)業(yè)務(wù)使用低權(quán)限賬號。 加入新的數(shù)據(jù)源不能影響已有的功能,保

    2024年01月16日
    瀏覽(32)
  • springboot+mybatis實現(xiàn)多數(shù)據(jù)源

    springboot+mybatis實現(xiàn)多數(shù)據(jù)源

    最近做項目碰到了一個需要連4個不同數(shù)據(jù)庫的需求,其中db1、db2表結(jié)構(gòu)都不相同;另外兩個數(shù)據(jù)庫same_db_private、same_db_public表結(jié)構(gòu)完全相同,一個對內(nèi)一個對外,只是從物理上隔離了數(shù)據(jù)而已。 所以打算通過靜態(tài)配置包路徑的方式來實現(xiàn)db1、db2的操作,并且通過擴展Spring的

    2024年02月09日
    瀏覽(28)
  • MyBatis整合Springboot多數(shù)據(jù)源實現(xiàn)

    MyBatis整合Springboot多數(shù)據(jù)源實現(xiàn)

    數(shù)據(jù)源,實際就是數(shù)據(jù)庫連接池,負(fù)責(zé)管理數(shù)據(jù)庫連接,在 Springboot 中,數(shù)據(jù)源通常以一個 bean 的形式存在于 IOC 容器中,也就是我們可以通過依賴注入的方式拿到數(shù)據(jù)源,然后再從數(shù)據(jù)源中獲取數(shù)據(jù)庫連接。 那么什么是多數(shù)據(jù)源呢,其實就是 IOC 容器中有多個數(shù)據(jù)源的 bea

    2023年04月22日
    瀏覽(25)
  • SpringBoot Mybatis 多數(shù)據(jù)源 MySQL+Oracle

    SpringBoot Mybatis 多數(shù)據(jù)源 MySQL+Oracle

    在SpringBoot Mybatis 項目中,需要連接 多個數(shù)據(jù)源,連接多個數(shù)據(jù)庫,需要連接一個MySQL數(shù)據(jù)庫和一個Oracle數(shù)據(jù)庫 ? spring.datasource.url數(shù)據(jù)庫的JDBC URL spring.datasource.jdbc-url用來重寫自定義連接池 Hikari沒有url屬性,但是有jdbcUrl屬性,在這中情況下必須使用jdbc_url MysqlDataSourceConfig 使用

    2024年02月11日
    瀏覽(33)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包