Java Mybatis數(shù)據(jù)源之工廠模式
工廠模式的工廠
DataSourceFactory是工廠角色的接口層
public interface DataSourceFactory {
void setProperties(Properties props);
DataSource getDataSource();
}這個兩個方法一個是設(shè)置DataSource的相關(guān)屬性,一個是獲取當(dāng)前的dataSource
UnpooledDataSourceFactory實現(xiàn)了這個接口,它的構(gòu)造方法中指定dataSource是UnpooledDataSource對象
public UnpooledDataSourceFactory() {
this.dataSource = new UnpooledDataSource();
}PooledDataSourceFactory繼承了UnpooledDataSourceFactory,構(gòu)造方法中返回了PooledDataSource對象,其他都是使用UnpooledDataSourceFactory的方法
public class PooledDataSourceFactory extends UnpooledDataSourceFactory {
public PooledDataSourceFactory() {
this.dataSource = new PooledDataSource();
}
}工廠模式的產(chǎn)品
DataSource的工廠模式的產(chǎn)品的接口,UnpooledDataSource和PooledDataSource都實現(xiàn)了這個方法,UnpooledDataSource是不使用數(shù)據(jù)庫連接池,而PooledDataSource是使用數(shù)據(jù)庫連接池
UnpooledDataSource的doGetConnection()方法:
private Connection doGetConnection(String username, String password) throws SQLException {
Properties props = new Properties();
if (driverProperties != null) {
props.putAll(driverProperties);
}
if (username != null) {
props.setProperty("user", username);
}
if (password != null) {
props.setProperty("password", password);
}
return doGetConnection(props);
}
private Connection doGetConnection(Properties properties) throws SQLException {
initializeDriver();
Connection connection = DriverManager.getConnection(url, properties);
configureConnection(connection);
return connection;
}這個方法就是典型的連接數(shù)據(jù)庫的操作了:
- 調(diào)用initializeDriver()方法初始化數(shù)據(jù)庫驅(qū)動,這個方法中進(jìn)行jdbc驅(qū)動的初始化,注冊到DriverManager中,同時保存到registeredDrivers中,registeredDrivers是UnpooledDataSource是成員變量,使用ConcurrentHashMap來進(jìn)行存儲,保證線程的安全性
- Connection connection = DriverManager.getConnection(url, properties);
- 創(chuàng)建數(shù)據(jù)庫連接
- 調(diào)用configureConnection()方法配置數(shù)據(jù)庫的連接
PooledDataSource是使用數(shù)據(jù)庫連接池來進(jìn)行緩存數(shù)據(jù)庫連接,但我們要設(shè)置合適的數(shù)據(jù)庫連接池的最大連接數(shù)和最大空閑連接數(shù)
有了數(shù)據(jù)庫連接池,在初始化的時候初始化數(shù)據(jù)庫連接信息,緩存到連接池中,當(dāng)需要連接數(shù)據(jù)庫的時候從數(shù)據(jù)庫連接池中獲取,使用完后不需要關(guān)閉連接而是返還給連接池,方便下次使用。
總結(jié)
本文主要介紹了Mybatis的數(shù)據(jù)源模塊,從工廠模式的角度分析了擔(dān)任工廠模式的工廠角色的接口DataSourceFactory和它對應(yīng)的實現(xiàn)類UnpooledDataSourceFactory、PooledDataSourceFactory,同時介紹了工廠模式的產(chǎn)品角色的DataSource接口和它對應(yīng)的實現(xiàn)類UnpooledDataSource、PooledDataSource,UnpooledDataSource不使用數(shù)據(jù)庫連接池,PooledDataSource使用了數(shù)據(jù)庫連接池。
到此這篇關(guān)于Java Mybatis數(shù)據(jù)源之工廠模式的文章就介紹到這了,更多相關(guān)Mybatis工廠模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
idea項目結(jié)構(gòu)中不顯示out文件夾的解決
本文通過圖片的方式詳細(xì)解釋操作步驟,使讀者能夠更直觀更方便地理解和執(zhí)行操作,同時,文章末尾祝福讀者步步高升,一帆風(fēng)順,展現(xiàn)了作者的人情味和親和力,整體來說,這是一篇簡單易懂、實用性強(qiáng)的操作指南2024-10-10
SpringBoot整合Redis實現(xiàn)刷票過濾功能
隨著互聯(lián)網(wǎng)的不斷發(fā)展,網(wǎng)站或APP的用戶流量增加,也衍生出了一些惡意刷量等問題,給數(shù)據(jù)分析及運(yùn)營帶來極大的困難,所以本文使用SpringBoot和Redis實現(xiàn)一個刷票過濾功能,需要的可以參考一下2023-06-06
Java數(shù)據(jù)結(jié)構(gòu)專題解析之棧和隊列的實現(xiàn)
從數(shù)據(jù)結(jié)構(gòu)的定義看,棧和隊列也是一種線性表。其不同之處在于棧和隊列的相關(guān)運(yùn)算具有特殊性,只是線性表相關(guān)運(yùn)算的一個子集。更準(zhǔn)確的說,一般線性表的插入、刪除運(yùn)算不受限制,而棧和隊列上的插入刪除運(yùn)算均受某種特殊限制。因此,棧和隊列也稱作操作受限的線性表2021-10-10
Java 利用binarySearch實現(xiàn)抽獎計算邏輯
這篇文章主要介紹了Java 利用binarySearch實現(xiàn)抽獎計算邏輯,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-12-12
springboot中的靜態(tài)資源加載順序優(yōu)先級
這篇文章主要介紹了springboot中的靜態(tài)資源加載順序優(yōu)先級,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09

