0


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

❤️作者主页:IT技术分享社区

❤️作者简介:大家好,我是IT技术分享社区的博主,从事C#、Java开发九年,对数据库、C#、Java、前端、运维、电脑技巧等经验丰富。

❤️个人荣誉: 数据库领域优质创作者🏆,华为云享专家🏆,阿里云专家博主🏆

❤️个人博客:IT技术分享社区

❤️公众号/小程序:IT技术分享社区 (运营五年)

❤️好文章点赞 👍 收藏 ⭐再看,养成习惯

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

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

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

2.3 新建测试demo

/**     * 测试mysql     */privatestaticvoidtestMysql(){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",newEntityListHandler());for(Entity entity : entityList){                System.out.println(entity.get("name"));}}catch(SQLException e){}finally{            DbUtil.close(conn);}}/**     * 测试sqlserver     */privatestaticvoidtestSqlServer(){DataSource ds = DSFactory.get("sqlserver");Connection conn =null;try{            conn = ds.getConnection();List<Entity> entityList = SqlExecutor.query(conn,"select * from t_user",newEntityListHandler());for(Entity entity : entityList){                System.out.println(entity.get("username"));}}catch(SQLException e){}finally{            DbUtil.close(conn);}}/**     * 直接代码写jdbc数据源 不推荐的方式     */privatestaticvoidtestDefineJdbc(){DruidDataSource ds =newDruidDataSource();        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",newEntityListHandler());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
版权归原作者 IT技术分享社区 所有, 如有侵权,请联系我们删除。

“Java实战:hutool-db实现多数据源配置”的评论:

还没有评论