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

  发布时间:2025-11-04 10:49:43   作者:玩站小弟   我要评论
​我们在日常开发中,经常会用到一个系统需要链接多个数据库来实现业务的需求,比如多个系统之间数据调用、两个数据之间同步等等。今天给大家分享使用Hutool-db实现多数据源配置,大家一起来学习一下吧!1 。

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

今天给大家分享使用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>1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.

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 = 123456driver = com.mysql.jdbc.Driver[sqlserver]url = jdbc:sqlserver://192.168.33.4:1433;DatabaseName=

DB

username =

sa

password = 123456driver = com.microsoft.sqlserver.jdbc.SQLServerDriver1.2.3.4.5.6.7.8.9.10.

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); } }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.45.46.47.48.49.50.51.52.53.54.55.56.57.58.59.60.61.62.63.64.65.66.
  • Tag:

相关文章

  • 小米5和5s拍照效果对比(小米5和5s相机表现如何?一图胜千言,你就知道!)

    摘要:如今,手机已经成为我们生活中必不可少的一部分,而拍照功能更是手机的一项重要指标。小米作为国内知名手机品牌,其旗舰机型小米5和5s的拍照效果备受关注。本文将从各个角度对比小米5和5s...
    2025-11-04
  • 预端接主干铜缆及其使用方法

    高密度布线产品和标准模块化设计在当今的数据中心和服务器机房中发挥着重要作用。这也发生在铜缆上,在安装网络电缆的过程中,传统上,电缆安装人员可能会选择自己端接类别电缆。但是,这会降低安装速度。此外,现场
    2025-11-04
  • 构建高性能Web服务器:Nginx的基本用法和配置技巧揭秘

    Nginx是一个高性能的开源Web服务器软件,也可以用作反向代理服务器、负载均衡器和缓存服务器。在本讲解中,我将详细介绍Nginx的基本用法以及如何配置它作为静态资源服务器、反向代理服务器、负载均衡器
    2025-11-04
  • Nginx配置指南:快速安装与反向代理设置

    Nginx是一个开源的高性能HTTP和反向代理服务器,它也可以用作邮件代理服务器和通用的TCP/UDP代理服务器。在本文中,我将详细介绍如何安装和配置Nginx,并介绍Nginx的主要配置文件以及常见
    2025-11-04
  • iCloud照片删除指南(掌握iCloud照片删除的方法,释放存储空间)

    摘要:随着手机摄影的普及,我们的相册往往充满了大量的照片。而iCloud作为苹果公司提供的云存储服务,可以帮助我们存储和备份照片,方便我们随时随地进行访问。然而,随着时间的推移,我们可能...
    2025-11-04
  • 正向代理和反向代理

    大家好,我是猿java。在日常工作中,我们经常会听到代理和反向代理这两个词,那么,什么是代理?什么又是反向代理?为什么有了代理还需要反向代理?他们之间有什么差异?今天我们就来一起聊一聊。一、定义
    2025-11-04

最新评论