Java Mybatis數(shù)據(jù)源之工廠模式
工廠模式的工廠
DataSourceFactory是工廠角色的接口層
public interface DataSourceFactory {
void setProperties(Properties props);
DataSource getDataSource();
}這個(gè)兩個(gè)方法一個(gè)是設(shè)置DataSource的相關(guān)屬性,一個(gè)是獲取當(dāng)前的dataSource
UnpooledDataSourceFactory實(shí)現(xiàn)了這個(gè)接口,它的構(gòu)造方法中指定dataSource是UnpooledDataSource對(duì)象
public UnpooledDataSourceFactory() {
this.dataSource = new UnpooledDataSource();
}PooledDataSourceFactory繼承了UnpooledDataSourceFactory,構(gòu)造方法中返回了PooledDataSource對(duì)象,其他都是使用UnpooledDataSourceFactory的方法
public class PooledDataSourceFactory extends UnpooledDataSourceFactory {
public PooledDataSourceFactory() {
this.dataSource = new PooledDataSource();
}
}工廠模式的產(chǎn)品
DataSource的工廠模式的產(chǎn)品的接口,UnpooledDataSource和PooledDataSource都實(shí)現(xiàn)了這個(gè)方法,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;
}這個(gè)方法就是典型的連接數(shù)據(jù)庫的操作了:
- 調(diào)用initializeDriver()方法初始化數(shù)據(jù)庫驅(qū)動(dòng),這個(gè)方法中進(jìn)行jdbc驅(qū)動(dòng)的初始化,注冊(cè)到DriverManager中,同時(shí)保存到registeredDrivers中,registeredDrivers是UnpooledDataSource是成員變量,使用ConcurrentHashMap來進(jìn)行存儲(chǔ),保證線程的安全性
- 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í)候初始化數(shù)據(jù)庫連接信息,緩存到連接池中,當(dāng)需要連接數(shù)據(jù)庫的時(shí)候從數(shù)據(jù)庫連接池中獲取,使用完后不需要關(guān)閉連接而是返還給連接池,方便下次使用。
總結(jié)
本文主要介紹了Mybatis的數(shù)據(jù)源模塊,從工廠模式的角度分析了擔(dān)任工廠模式的工廠角色的接口DataSourceFactory和它對(duì)應(yīng)的實(shí)現(xiàn)類UnpooledDataSourceFactory、PooledDataSourceFactory,同時(shí)介紹了工廠模式的產(chǎn)品角色的DataSource接口和它對(duì)應(yīng)的實(shí)現(xiàn)類UnpooledDataSource、PooledDataSource,UnpooledDataSource不使用數(shù)據(jù)庫連接池,PooledDataSource使用了數(shù)據(jù)庫連接池。
到此這篇關(guān)于Java Mybatis數(shù)據(jù)源之工廠模式的文章就介紹到這了,更多相關(guān)Mybatis工廠模式內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何修改FeginCilent定義的服務(wù)名到指定服務(wù)
這篇文章主要介紹了修改FeginCilent定義的服務(wù)名到指定服務(wù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
Java計(jì)算代碼段執(zhí)行時(shí)間的詳細(xì)過程
java里計(jì)算代碼段執(zhí)行時(shí)間可以有兩種方法,一種是毫秒級(jí)別的計(jì)算,另一種是更精確的納秒級(jí)別的計(jì)算,這篇文章主要介紹了java計(jì)算代碼段執(zhí)行時(shí)間,需要的朋友可以參考下2023-02-02
Java中的構(gòu)造方法(構(gòu)造函數(shù))與普通方法區(qū)別及說明
這篇文章主要介紹了Java中的構(gòu)造方法(構(gòu)造函數(shù))與普通方法區(qū)別及說明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
Java String字符串內(nèi)容實(shí)現(xiàn)添加雙引號(hào)
這篇文章主要介紹了Java String字符串內(nèi)容實(shí)現(xiàn)添加雙引號(hào),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-09-09
如何解決java中遇到的for input string: "" 報(bào)錯(cuò)問題
在本篇文章里小編給大家整理的是一篇關(guān)于如何解決java中遇到的(for input string: "")報(bào)錯(cuò)內(nèi)容,需要的朋友們可以學(xué)習(xí)下。2020-02-02
mybatisPlus自動(dòng)填充更新時(shí)間的示例代碼
本文主要介紹了mybatisPlus自動(dòng)填充更新時(shí)間,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09

