Java實(shí)戰(zhàn)之用hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置
前言
我們?cè)谌粘i_(kāi)發(fā)中,經(jīng)常會(huì)用到一個(gè)系統(tǒng)需要鏈接多個(gè)數(shù)據(jù)庫(kù)來(lái)實(shí)現(xiàn)業(yè)務(wù)的需求,比如多個(gè)系統(tǒng)之間數(shù)據(jù)調(diào)用、兩個(gè)數(shù)據(jù)之間同步等等。
今天給大家分享使用Hutool-db實(shí)現(xiàn)多數(shù)據(jù)源配置,大家一起來(lái)學(xué)習(xí)一下吧!
1、hutool-db介紹
Hutool-db是一個(gè)在JDBC基礎(chǔ)上封裝的數(shù)據(jù)庫(kù)操作工具類(lèi),通過(guò)包裝,使用ActiveRecord思想操作數(shù)據(jù)庫(kù)。在Hutool-db中,使用Entity(本質(zhì)上是個(gè)Map)代替Bean來(lái)使數(shù)據(jù)庫(kù)操作更加靈活,同時(shí)提供Bean和Entity的轉(zhuǎn)換提供傳統(tǒng)ORM的兼容支持。

數(shù)據(jù)源 DataSourceSQL執(zhí)行器 SqlExecutorCRUD的封裝 Db、SqlConnRunner SqlRunner支持事務(wù)的CRUD封裝 Session各種結(jié)果集處理類(lèi) 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);
}
}
/**
* 直接代碼寫(xiě)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發(fā)送email一般步驟(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇java發(fā)送email一般步驟(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
Java 網(wǎng)絡(luò)爬蟲(chóng)基礎(chǔ)知識(shí)入門(mén)解析
這篇文章主要介紹了Java 網(wǎng)絡(luò)爬蟲(chóng)基礎(chǔ)知識(shí)入門(mén)解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
Mybatis配置錯(cuò)誤:java.lang.ExceptionInInitializerError
這篇文章主要介紹了Mybatis配置錯(cuò)誤:java.lang.ExceptionInInitializerError的相關(guān)資料,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
Java基于IDEA實(shí)現(xiàn)qq郵件發(fā)送小程序
這篇文章主要介紹了Java基于IDEA實(shí)現(xiàn)qq郵件發(fā)送小程序功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
Java23種設(shè)計(jì)模式中的單例模式你了解嗎
這篇文章主要為大家詳細(xì)介紹了Java23種設(shè)計(jì)模式中的單例模式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-02-02

