欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)戰(zhàn)之用hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置

 更新時(shí)間:2022年12月19日 11:21:56   作者:IT技術(shù)分享社區(qū)  
在微服務(wù)搭建中經(jīng)常會(huì)使用到多數(shù)據(jù)庫(kù)情形這個(gè)時(shí)候,下面這篇文章主要給大家介紹了關(guān)于Java實(shí)戰(zhàn)之用hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

我們?cè)谌粘i_發(fā)中,經(jīng)常會(huì)用到一個(gè)系統(tǒng)需要鏈接多個(gè)數(shù)據(jù)庫(kù)來實(shí)現(xiàn)業(yè)務(wù)的需求,比如多個(gè)系統(tǒng)之間數(shù)據(jù)調(diào)用、兩個(gè)數(shù)據(jù)之間同步等等。

今天給大家分享使用Hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置,大家一起來學(xué)習(xí)一下吧!

1、hutool-db介紹

Hutool-db是一個(gè)在JDBC基礎(chǔ)上封裝的數(shù)據(jù)庫(kù)操作工具類,通過包裝,使用ActiveRecord思想操作數(shù)據(jù)庫(kù)。在Hutool-db中,使用Entity(本質(zhì)上是個(gè)Map)代替Bean來使數(shù)據(jù)庫(kù)操作更加靈活,同時(shí)提供Bean和Entity的轉(zhuǎn)換提供傳統(tǒng)ORM的兼容支持。

數(shù)據(jù)源 DataSourceSQL執(zhí)行器 SqlExecutorCRUD的封裝 Db、SqlConnRunner SqlRunner支持事務(wù)的CRUD封裝 Session各種結(jié)果集處理類 handler數(shù)據(jù)庫(kù)的一些工具方法匯總 DbUtil

2、新建一個(gè)Maven項(xiàng)目

2.1 導(dǎo)入依賴包

   <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 新建測(cè)試demo

/**
     * 測(cè)試mysql
     */
    private static void testMysql() {
        DataSource ds = DSFactory.get("mysql");
        Db.use(ds);
        Connection conn = null;
        try {
            conn = ds.getConnection();
            // 插入語(yǔ)句
            SqlExecutor.execute(conn, "insert into t_user (name,age) value ('小張',35)");
            // 更新語(yǔ)句
            SqlExecutor.execute(conn, "update t_user set name='小明002' where id=2 ");
            // 刪除語(yǔ)句
            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);
        }
    }
 
    /**
     * 測(cè)試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數(shù)據(jù)源 不推薦的方式
     */
    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);
        }
    }

總結(jié)

到此這篇關(guān)于Java實(shí)戰(zhàn)之用hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置的文章就介紹到這了,更多相關(guān)Java hutool-db多數(shù)據(jù)源配置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java 學(xué)習(xí)筆記(入門篇)_java程序helloWorld

    java 學(xué)習(xí)筆記(入門篇)_java程序helloWorld

    安裝配置完Java的jdk,下面就開始寫第一個(gè)java程序--hello World.用來在控制臺(tái)輸出“Hello World”,接下來詳細(xì)介紹,感興趣的朋友可以參考下
    2013-01-01
  • Druid之連接創(chuàng)建及銷毀示例詳解

    Druid之連接創(chuàng)建及銷毀示例詳解

    這篇文章主要為大家介紹了Druid之連接創(chuàng)建及銷毀示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • spring cloud中啟動(dòng)Eureka Server的方法

    spring cloud中啟動(dòng)Eureka Server的方法

    本篇文章主要介紹了spring cloud中啟動(dòng)Eureka Server的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • java-thymeleaf的使用方式

    java-thymeleaf的使用方式

    這篇文章主要介紹了java-thymeleaf的使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • SpringBoot整合Echarts繪制靜態(tài)數(shù)據(jù)柱狀圖和餅圖

    SpringBoot整合Echarts繪制靜態(tài)數(shù)據(jù)柱狀圖和餅圖

    這篇文章給大家介紹了SpringBoot整合Echarts繪制靜態(tài)數(shù)據(jù)柱狀圖和餅圖,文中通過代碼示例給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-03-03
  • hashset去除重復(fù)值原理實(shí)例解析

    hashset去除重復(fù)值原理實(shí)例解析

    這篇文章主要介紹了hashset去除重復(fù)值原理實(shí)例解析,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • Java中的包(Package)與導(dǎo)入(Import)示例詳解

    Java中的包(Package)與導(dǎo)入(Import)示例詳解

    這篇文章主要詳細(xì)介紹了Java中的包(Package)和導(dǎo)入(Import)概念,包括包的定義、作用、JDK中主要的包、導(dǎo)入的目的與用法、特殊情況的導(dǎo)入、靜態(tài)導(dǎo)入、包的訪問權(quán)限和命名規(guī)范,文章通過豐富的解釋和代碼示例,幫助讀者深入理解這些概念的實(shí)際應(yīng)用,需要的朋友可以參考下
    2024-11-11
  • Mybatis插入語(yǔ)句默認(rèn)值不生效的問題及解決

    Mybatis插入語(yǔ)句默認(rèn)值不生效的問題及解決

    這篇文章主要介紹了Mybatis插入語(yǔ)句默認(rèn)值不生效的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 打卡每日10道面試題——JVM篇

    打卡每日10道面試題——JVM篇

    總結(jié)了JVM一些經(jīng)典面試題,分享出我自己的解題思路,希望對(duì)大家有幫助,有哪里你覺得不正確的話,歡迎指出,后續(xù)有空會(huì)更新,希望大家能夠喜歡
    2021-06-06
  • shade解決mybatis包沖突問題

    shade解決mybatis包沖突問題

    這篇文章主要介紹了shade解決mybatis包沖突問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08

最新評(píng)論