阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

如何用hutool-db实现多数据源配置

91次阅读
没有评论

共计 2366 个字符,预计需要花费 6 分钟才能阅读完成。

导读 Hutool-db 是一个在 JDBC 基础上封装的数据库操作工具类,通过包装,使用 ActiveRecord 思想操作数据库。我们在日常开发中,经常会用到一个系统需要链接多个数据库来实现业务的需求,比如多个系统之间数据调用、两个数据之间同步等等。

如何用 hutool-db 实现多数据源配置

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

hutool-db 介绍

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

如何用 hutool-db 实现多数据源配置

  • 数据源 DataSource
  • SQL 执行器 SqlExecutor
  • CRUD 的封装 Db、SqlConnRunner SqlRunner
  • 支持事务的 CRUD 封装 Session
  • 各种结果集处理类 handler
  • 数据库的一些工具方法汇总 DbUtil
  • 新建一个 Maven 项目
    导入依赖包
    
                mysql
                mysql-connector-java
                5.1.45
            
            
                com.microsoft.sqlserver
                sqljdbc4
                4.0
            
            
                cn.hutool
                hutool-db
                5.7.22
            
            
                com.alibaba
                druid
                1.2.9
            
    新建 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
    新建测试 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 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 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 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);
            }
        }

    阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

    腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

    代金券:在阿里云专用满减优惠券

    正文完
    星哥玩云-微信公众号
    post-qrcode
     0
    星锅
    版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计2366字。
    转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
    【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
    阿里云-最新活动爆款每日限量供应
    评论(没有评论)
    验证码
    【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中