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

数据库 其他数据库
Hutool-db是一个在JDBC基础上封装的数据库操作工具类,通过包装,使用ActiveRecord思想操作数据库。

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

今天给大家分享使用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);
}
}
责任编辑:武晓燕 来源: IT技术分享社区
相关推荐

2023-09-07 08:39:39

copy属性数据源

2024-10-30 10:22:17

2020-12-31 07:55:33

spring bootMybatis数据库

2020-11-24 09:56:12

数据源读写分离

2023-01-04 09:33:31

SpringBootMybatis

2017-07-21 14:50:15

数据库DB分库事务处理

2010-12-27 09:59:11

ODBC数据源

2009-06-15 13:24:46

JBoss数据源

2023-06-07 08:08:37

MybatisSpringBoot

2023-10-18 15:25:29

数据源数据库

2009-08-14 10:26:27

ibatis多数据源

2023-10-31 07:52:53

多数据源管理后端

2020-06-02 07:55:31

SpringBoot多数据源

2022-05-18 12:04:19

Mybatis数据源Spring

2020-03-13 14:05:14

SpringBoot+数据源Java

2022-05-10 10:43:35

数据源动态切换Spring

2014-11-20 09:47:06

Java

2023-01-10 16:30:22

Spring数据库

2023-11-27 07:33:55

2010-05-14 15:32:51

配置MySQL
点赞
收藏

51CTO技术栈公众号