Java实战之用hutool-db实现多数据源配置
作者:IT技术分享社区 时间:2023-11-28 19:37:10
前言
我们在日常开发中,经常会用到一个系统需要链接多个数据库来实现业务的需求,比如多个系统之间数据调用、两个数据之间同步等等。
今天给大家分享使用Hutool-db实现多数据源配置,大家一起来学习一下吧!
1、hutool-db介绍
Hutool-db是一个在JDBC基础上封装的数据库操作工具类,通过包装,使用ActiveRecord思想操作数据库。在Hutool-db中,使用Entity(本质上是个Map)代替Bean来使数据库操作更加灵活,同时提供Bean和Entity的转换提供传统ORM的兼容支持。
数据源 DataSourceSQL执行器 SqlExecutorCRUD的封装 Db、SqlConnRunner SqlRunner支持事务的CRUD封装 Session各种结果集处理类 handler数据库的一些工具方法汇总 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&serverTimezone=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://blog.csdn.net/xishining/article/details/128350363
标签:java,hutool-db,多数据源配置
0
投稿
猜你喜欢
Java使用substring()截取(提取)子字符串
2023-09-29 17:02:04
Java 反射(Reflect)详解
2022-09-27 08:34:44
Java中对话框的弹出方法
2022-04-24 14:35:52
Android 调用系统联系人界面(添加联系人,添加已有联系人,编辑和修改)
2023-12-10 17:08:08
Android手势密码的实现
2023-03-09 09:23:01
C# 定时器定时更新的简单实例
2023-01-08 12:45:50
详解Android 多级联动控件实现思路讨论
2021-10-10 21:45:53
Java File类 mkdir 不能创建多层目录的解决
2022-12-01 09:20:18
c#创建圆形类Circle、矩形类实现代码
2023-08-18 19:59:12
Java获取用户IP属地模拟抖音详解
2023-04-18 02:01:29
C#实现3步手动建DataGridView的方法
2021-10-13 22:35:56
Android自定义播放器控件VideoView
2023-06-25 03:29:00
C# Invoke,begininvoke的用法详解
2023-07-21 01:55:55
winform C#获得Mac地址,IP地址,子网掩码,默认网关的实例
2021-06-28 20:45:50
java实现人工智能化屏幕监控窗口
2022-09-16 18:09:19
C#实现简单获取及设置Session类
2021-07-09 06:19:27
java实现sftp客户端上传文件以及文件夹的功能代码
2023-02-14 22:07:28
Java中Servlet的生命周期详解
2023-09-10 03:57:59
关于SpringCloud的微服务结构及微服务远程调用
2021-11-06 20:11:45
Android实现背景颜色滑动渐变效果的全过程
2021-08-28 09:23:51