Java实战:hutool-db实现多数据源配置

​我们在日常开发中,经常会用到一个系统需要链接多个数据库来实现业务的需求,比如多个系统之间数据调用、两个数据之间同步等等。

今天给大家分享使用Hutool-db实现多数据源配置,大家一起来学习一下吧!

1、hutool-db介绍

Hutool-db是一个在JDBC基础上封装的数据库操作工具类,通过包装,使用ActiveRecord思想操作数据库。在Hutool-db中,使用Entity(本质上是个Map)代替Bean来使数据库操作更加灵活,同时提供Bean和Entity的转换提供传统ORM的兼容支持。

1.  数据源 DataSource

2.  SQL执行器 SqlExecutor

3.  CRUD的封装 Db、SqlConnRunner SqlRunner

4.  支持事务的CRUD封装 Session

5.  各种结果集处理类 handler

6.  数据库的一些工具方法汇总 DbUtil

2、新建一个Maven项目

2.1 导入依赖包

<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependency>
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0</version>
</dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-db</artifactId>
<version>5.7.22</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.9</version>
</dependency>

2.2 新建db.setting配置文件

src/main/resources/config/db.setting

[mysql]
url = jdbc:mysql://127.0.0.1:3306/mydb?characterEncoding=utf-8&useSSL=false&serverTimezone=GMT
username = root
password =123456
driver = com.mysql.jdbc.Driver
[sqlserver]
url = jdbc:sqlserver://192.168.33.4:1433;DatabaseName=DB
username = sa
password =123456
driver = com.microsoft.sqlserver.jdbc.SQLServerDriver

2.3 新建测试demo

/**
* 测试mysql
*/
private static void testMysql(){
DataSource ds = DSFactory.get("mysql");
Db.use(ds);
Connection conn =null;
try {
conn = ds.getConnection();
// 插入语句
SqlExecutor.execute(conn,"insert into t_user (name,age) value ('小张',35)");
// 更新语句
SqlExecutor.execute(conn,"update t_user set name='小明002' where id=2 ");
// 删除语句
SqlExecutor.execute(conn,"delete from t_user where id=2 ");
List<Entity> entityList = SqlExecutor.query(conn,"select * from t_user limit 50", new EntityListHandler());
for (Entity entity : entityList){
System.out.println(entity.get("name"));
}
} catch (SQLException e){

} finally {
DbUtil.close(conn);
}
}

/**
* 测试sqlserver
*/
private static void testSqlServer(){
DataSource ds = DSFactory.get("sqlserver");
Connection conn =null;
try {
conn = ds.getConnection();
List<Entity> entityList = SqlExecutor.query(conn,"select * from t_user", new EntityListHandler());
for (Entity entity : entityList){
System.out.println(entity.get("username"));
}
} catch (SQLException e){

} finally {
DbUtil.close(conn);
}
}

/**
* 直接代码写jdbc数据源 不推荐的方式
*/
private static void testDefineJdbc(){
DruidDataSource ds = new DruidDataSource();
ds.setUrl("jdbc:mysql://127.0.0.1:3306/mydb?characterEncoding=utf-8&useSSL=false&serverTimeznotallow=GMT");
ds.setUsername("root");
ds.setPassword("12345678");
Connection conn =null;
try {
conn = ds.getConnection();
List<Entity> entityList = SqlExecutor.query(conn,"select * from t_user", new EntityListHandler());
for (Entity entity : entityList){
System.out.println(entity.get("name"));
}
} catch (SQLException e){

} finally {
DbUtil.close(conn);
}
}

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/255793.html<

(0)
运维的头像运维
上一篇2025-05-01 00:29
下一篇 2025-05-01 00:30

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注