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的兼容支持。

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

数据源 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
  • asp之家 软件编程 m.aspxhome.com