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

Crq
Crq
管理员
1796
文章
0
粉丝
Linux教程评论5字数 456阅读1分31秒阅读模式
摘要Hutool-db是一个在JDBC基础上封装的数据库操作工具类,通过包装,使用ActiveRecord思想操作数据库。我们在日常开发中,经常会用到一个系统需要链接多个数据库来实现业...

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

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

hutool-db介绍

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

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

  • 数据源 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);
            }
        }

    weinxin
    我的微信
    微信号已复制
    我的微信
    这是我的微信扫一扫
     
    Crq
    • 本文由 Crq 发表于2025年3月4日 15:32:34
    • 转载请注明:https://www.cncrq.com/13302.html
    教你摸清 Linux PC 的性能底细? Linux教程

    教你摸清 Linux PC 的性能底细?

    基准测试是一项测试或一系列测试,用来确定某个计算机硬件运行起来的状况有多好。在许多情况下,“基准测试”实际上等同于“压力测试”。通过测试硬件的极限,然后可以将测得的结果与其他硬件测...
    如何解决缓存失效问题 Linux教程

    如何解决缓存失效问题

    在如今大数据的时代下,高并发高可用是所有软件开发都追求的目标,为了实现这一目标,缓存的使用是每一个高并发系统都会涉及到的,使用缓存可以保障系统的运行效率,提高系统的健壮性。
    怎么使用树莓派和 iPad Pro 备份图片 Linux教程

    怎么使用树莓派和 iPad Pro 备份图片

    我在很长的时间内一直在寻找一个旅行中备份图片的理想方法,把 SD 卡放进你的相机包会让你暴露在太多的风险之中:SD 卡可能丢失或者被盗,数据可能损坏或者在传输过程中失败。
    听说awk语言也可以编写脚本 Linux教程

    听说awk语言也可以编写脚本

    从 awk 系列开始,我们都是在命令行或者脚本文件里写一些简短的 awk 命令和程序。然而 awk 和 shell 一样也是一个解释型语言。通过从开始到现在的一系列的学习,你现在能...
    匿名

    发表评论

    匿名网友
    :?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:
    确定

    拖动滑块以完成验证