基于SpringBoot+hutool实现项目的多数据源

 更新时间:2026年04月15日 08:34:10   作者:昵称为空C  
本文介绍了基于SpringBoot和hutool实现多数据源的方法,通过hutool的db工具类实现小型业务的数据库连接,不会影响主流程业务,同时提供了官方文档链接、数据源配置和测试类访问地址,需要的朋友可以参考下

摘要:本文主要介绍如何基于SpringBoot+hutool实现项目的多数据源。在我们已有的一些复杂项目如果想直接基于默认的DataSource实现多数据源代价比较大,而我们可以通过hutooldb工具类来实现小型业务的数据库连接,并不会影响主流程业务。

官方文档:https://doc.hutool.cn/pages/db/index/#%E7%94%B1%E6%9D%A5

pom.xml

<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>com.example</groupId>
        <artifactId>huzhihui-sp3-home</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>
    <artifactId>sp3-hutool</artifactId>
    <packaging>jar</packaging>
    <name>sp3-hutool</name>
    <url>http://maven.apache.org</url>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.8.39</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <dependency>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <executions>
                    <execution>
                        <id>copy-external-dependencies</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${project.build.directory}/lib/external</outputDirectory>
                            <includeScope>compile</includeScope>
                            <excludeGroupIds>cn.hutool</excludeGroupIds>
                        </configuration>
                    </execution>
                    <execution>
                        <id>copy-internal-dependencies</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${project.build.directory}/lib/internal</outputDirectory>
                            <includeScope>compile</includeScope>
                            <includeGroupIds>cn.hutool</includeGroupIds>
                        </configuration>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>21</source>
                    <target>21</target>
                    <encoding>UTF-8</encoding>
                    <!-- 如果使用预览特性 -->
                    <compilerArgs>
                        <arg>--enable-preview</arg>
                    </compilerArgs>
                    <release>21</release>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

DataSourceConfig

数据源配置,我这里使用的写死的配置,实际过程中可以切换为从配置文件中读取,或者从数据库中读取

@Configuration
public class DataSourceConfig {
    @Bean
    public Db masterDb() {
        // 打印日志
        SqlLog.INSTANCE.init(true, true, true, Level.INFO);
        HikariConfig hikariConfig = new HikariConfig();
        hikariConfig.setDriverClassName("com.mysql.cj.jdbc.Driver");
        hikariConfig.setJdbcUrl("jdbc:mysql://192.168.8.134:30635/test_1?useSSL=false&serverTimezone=UTC");
        hikariConfig.setUsername("super_admin");
        hikariConfig.setPassword("super_admin");
        return Db.use(new HikariDataSource(hikariConfig));
    }
}

DbController测试类

@RestController
@RequestMapping(value = "/db")
public class DbController {

    @Autowired
    private Db db;

    @GetMapping(value = "/all")
    public Object all() throws Exception {
        List<Entity> query = db.query("select * from databasechangelog");
        for (Entity entity : query) {
            entity.forEach((key, value) -> System.out.println(key + ":" + value));
        }
        return query;
    }

    @GetMapping(value = "/school")
    public Object school() throws Exception {
        List<School> query = db.query("select * from school", School.class);
        return query;
    }

    @Data
    public static class School {
        private Long id;

        private String name;

        private LocalDateTime createTime;

        private LocalDateTime timeZone;

        private LocalDateTime timeNoZone;
    }
}
  • 访问:http://localhost:8080/db/school

以上就是基于SpringBoot+hutool实现项目的多数据源的详细内容,更多关于SpringBoot hutool多数据源的资料请关注脚本之家其它相关文章!

相关文章

  • javaweb图书商城设计之分类模块(2)

    javaweb图书商城设计之分类模块(2)

    这篇文章主要为大家详细介绍了javaweb图书商城设计之分类模块的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-11-11
  • idea代码模板设置方式

    idea代码模板设置方式

    这篇文章主要介绍了idea代码模板设置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Java中String、StringBuffer和StringBuilder的区别

    Java中String、StringBuffer和StringBuilder的区别

    这篇文章主要介绍了Java中String、StringBuffer和StringBuilder的区别,StringBuilder与StringBuffer都继承自AbstractStringBuilder类,在AbstractStringBuilder中也是使用字符数组保存字符串char[]value但是没有final关键字修饰,所以这两个可变,需要的朋友可以参考下
    2024-01-01
  • java验证码组件kaptcha使用方法

    java验证码组件kaptcha使用方法

    这篇文章主要介绍了java验证码组件kaptcha使用方法,很不错的一个组件,可以在JAVA开发中使用,大家都试试吧
    2013-11-11
  • 关于Java中静态代码块的执行浅析

    关于Java中静态代码块的执行浅析

    这篇文章主要给大家介绍了关于Java中静态代码块执行的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-09-09
  • Java中HashMap的put过程详解

    Java中HashMap的put过程详解

    这篇文章主要介绍了Java中HashMap的put过程详解,HashMap有4个构造器,其他构造器如果用户没有传入initialCapacity 和loadFactor这两个参数,会使用默认值一般如果new HashMap()不传值,需要的朋友可以参考下
    2023-07-07
  • java开发的工厂方法模式及抽象工厂验证示例

    java开发的工厂方法模式及抽象工厂验证示例

    这篇文章主要为大家介绍了java开发中的工厂方法模式以及抽象工厂的验证示例,有需要的朋友可以借鉴参考下希望能够有所帮助祝大家多多进步
    2021-10-10
  • Java中synchronized关键字引出的多种锁 问题

    Java中synchronized关键字引出的多种锁 问题

    synchronized关键字是JAVA中常用的同步功能,提供了简单易用的锁功能。这篇文章主要介绍了Java中synchronized关键字引出的多种锁问题,需要的朋友可以参考下
    2019-07-07
  • java批量解析微信dat文件

    java批量解析微信dat文件

    这篇文章主要为大家详细介绍了java批量解析微信dat文件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Springboot JPA级联操作的实现(一对一、一对多、多对多)

    Springboot JPA级联操作的实现(一对一、一对多、多对多)

    本文深入解析JPA中的一对一、一对多和多对多级联操作,包括实体间的关系建立、查询、保存、刷新和删除等操作,具有一定的参考价值,感兴趣的可以了解一下
    2025-07-07

最新评论