Javaweb筆記(十四):MySql數(shù)據(jù)庫連接池

使用DBCP連接池連接數(shù)據(jù)庫

在使用dbcp連接池是需要下載相關(guān)的jar包進(jìn)行配置


072001.png

使用DBCP常用方法說明:

方法 說明
setUsername(String userName) 設(shè)置建立連接數(shù)據(jù)庫的用戶名
setPassword(String password) 設(shè)置建立連接數(shù)據(jù)庫的密碼
setUrl(String url) 設(shè)置連接數(shù)據(jù)庫的地址
setDriverClassName( String driverClassName) 設(shè)置JDBC驅(qū)動類的名稱
getConnection() 獲取連接數(shù)據(jù)庫的連接,返回值Connection對象
setMaxIdle(int maxIdle) 設(shè)置連接池最大空閑連接數(shù)
setMinIdel(int minIdel) 設(shè)置連接池最小空閑連接數(shù)

使用dbcp 連接池進(jìn)行數(shù)據(jù)庫的連接 連接池對象BasicDataSource操作連接池的配置信息,BasicDataSource實現(xiàn)了DataSource接口殴蹄;

public class DBPCConnectionPool {

    /**
     * 使用dbcp來進(jìn)行連接池的連接和獲取連接對象
     * 
     * @throws SQLException
     */
    @Test
    public void connectionPoolByApacheCommoms() throws SQLException {
        // 獲取連接池對象 BasicDataSource
        BasicDataSource dataSource = new BasicDataSource();
        // 加載數(shù)據(jù)庫驅(qū)動
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        // 設(shè)置數(shù)據(jù)庫地址
        dataSource.setUrl("jdbc:mysql://localhost:3306/testdb");
        // 設(shè)置連接數(shù)據(jù)庫用戶
        dataSource.setUsername("root");
        // 設(shè)置連接數(shù)據(jù)庫密碼
        dataSource.setPassword("12345678");

        // 獲取連接對象
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        System.out.println(connection.getClass().getName());
        // 將將連接對象歸還連接池
        connection.close();
    }
}

代碼中connection.close()方法不是關(guān)閉連接的操作讯蒲,是將當(dāng)前使用連接歸還到連接池中;

使用c3p0連接池連接數(shù)據(jù)庫

在使用c3p0連接池是需要下載相關(guān)的jar包進(jìn)行配置


072002.png

使用c3p0連接池操作數(shù)據(jù)庫中审葬,使用到的連接連接池對象是ComboPooledDataSource野揪,通過連接池對象可以對連接池的一些屬性進(jìn)行配置吓坚,數(shù)據(jù)庫驅(qū)動,數(shù)據(jù)庫地址是牢,連接數(shù)據(jù)庫的用戶名僵井,密碼等,但是在使用c3p0連接池是驳棱,會有三種連接方式:
1.java代碼進(jìn)行連接池對象的設(shè)置
2.加載配置文件默認(rèn)配置
3.加載配置文件中自定義的配置信息
使用此c3p0連接池連接數(shù)據(jù)庫準(zhǔn)備條件:
1.準(zhǔn)備c3p0的jar包
2.創(chuàng)建c3p0-config.xml配置文件(使用配置文件時創(chuàng)建批什,創(chuàng)建的配置文件名稱必須為"c3p0-config.xml",且文件路徑必須在項目src根目錄下

1.連接池配置信息-java代碼配置
/**
     * 連接池配置信息-java代碼配置
     * 
     * @throws PropertyVetoException
     * @throws SQLException
     */
    @Test
    public void connectPoolByC3P0CodeSettings() throws PropertyVetoException, SQLException {
        // 初始化連接池對象
        ComboPooledDataSource dataSource = new ComboPooledDataSource();

        // 設(shè)置數(shù)據(jù)庫驅(qū)動
        dataSource.setDriverClass("com.mysql.jdbc.Driver");
        // 設(shè)置數(shù)據(jù)庫地址
        dataSource.setJdbcUrl("jdbc:mysql://localhost:3306/testdb");
        // 設(shè)置數(shù)據(jù)庫登錄名
        dataSource.setUser("root");
        // 設(shè)置數(shù)據(jù)庫登錄密碼
        dataSource.setPassword("12345678");

        // 連接池最大容量
        dataSource.setMaxPoolSize(20);
        // 初始化連接池容量
        dataSource.setInitialPoolSize(10);
        // 設(shè)置連接池容量滿之后創(chuàng)建連接對象的增量
        dataSource.setAcquireIncrement(5);
        // 獲取連接對象
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        // 將連接對象歸還連接池
        connection.close();
    }
2.加載配置文件默認(rèn)配置

在src根目錄下創(chuàng)建文件c3p0-config.xml社搅,文件內(nèi)容為:

<?xml version="1.0" encoding="UTF-8"?>
<c3p0-config>
  <default-config>
    <property name="checkoutTimeout">30000</property>
    <property name="idleConnectionTestPeriod">30</property>
    <property name="initialPoolSize">10</property>
    <property name="maxIdleTime">30</property>
    <property name="maxPoolSize">100</property>
    <property name="minPoolSize">10</property>
    <property name="maxStatements">200</property>
    <property name="driverClass">com.mysql.jdbc.Driver</property>
    <property name="jdbcUrl">jdbc:mysql://localhost:3306/testdb</property>
    <property name="user">root</property>
    <property name="password">12345678</property>
  </default-config>

  <!-- This app is massive! -->
  <named-config name="coustom-config"> 
    <property name="acquireIncrement">50</property>
    <property name="initialPoolSize">100</property>
    <property name="minPoolSize">50</property>
    <property name="maxPoolSize">1000</property>

    <!-- intergalactoApp adopts a different approach to configuring statement caching -->
    <property name="maxStatements">0</property> 
    <property name="maxStatementsPerConnection">5</property>
  </named-config>
</c3p0-config>

配置文件創(chuàng)建成功則擼一波代碼驻债,來加載默認(rèn)配置信息獲取連接池對象乳规。

/**
     * 使用c3p0默認(rèn)的配置文件進(jìn)行連接池對象的創(chuàng)建
     * 
     * 在創(chuàng)建c3p0連接池對象時,會自動掃描項目src根目錄下是否存在c3p0-config.xml配置文件合呐,存在則加載配置文件中 默認(rèn)的配置信息
     * 
     * @throws SQLException
     */
    @Test
    public void connectionPoolByC3P0DefaultConfig() throws SQLException {
        // 初始化連接池對象
        ComboPooledDataSource dataSource = new ComboPooledDataSource();
        // 獲取連接對象
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        // 將連接對象歸還連接池
        connection.close();
    }
3.加載配置文件中自定義的配置信息

在加載配置文件時暮的,我們代碼中會使用ComboPooledDataSource類有參的構(gòu)造方法:

    /**
     * 使用c3p0自定義的配置文件進(jìn)行連接池對象的創(chuàng)建
     * 在創(chuàng)建c3p0連接池對象時,會自動掃描項目src根目錄下是否存在c3p0-config.xml配置文件淌实,存在則加載配置文件中冻辩,則在初始化
     * 連接池對象通過連接池對象構(gòu)造方法傳參來進(jìn)行培配置信息的加載
     * 
     * @throws SQLException
     */
    @Test
    public void connectionPoolByC3P0CoustomConfig() throws SQLException {
        // 初始化連接池對象
        ComboPooledDataSource dataSource = new ComboPooledDataSource("coustom-config");
        // 獲取連接對象
        Connection connection = dataSource.getConnection();
        System.out.println(connection);
        // 將連接對象歸還連接池
        connection.close();
    }
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市拆祈,隨后出現(xiàn)的幾起案子恨闪,更是在濱河造成了極大的恐慌,老刑警劉巖放坏,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咙咽,死亡現(xiàn)場離奇詭異,居然都是意外死亡淤年,警方通過查閱死者的電腦和手機(jī)钧敞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來麸粮,“玉大人犁享,你說我怎么就攤上這事”荩” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵桨吊,是天一觀的道長威根。 經(jīng)常有香客問我,道長视乐,這世上最難降的妖魔是什么洛搀? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮佑淀,結(jié)果婚禮上留美,老公的妹妹穿的比我還像新娘。我一直安慰自己伸刃,他們只是感情好谎砾,可當(dāng)我...
    茶點故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著捧颅,像睡著了一般景图。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上碉哑,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天挚币,我揣著相機(jī)與錄音亮蒋,去河邊找鬼。 笑死妆毕,一個胖子當(dāng)著我的面吹牛慎玖,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播笛粘,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼趁怔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了闰蛔?” 一聲冷哼從身側(cè)響起痕钢,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎序六,沒想到半個月后任连,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡例诀,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年随抠,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片繁涂。...
    茶點故事閱讀 38,789評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡拱她,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出扔罪,到底是詐尸還是另有隱情秉沼,我是刑警寧澤,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布矿酵,位于F島的核電站唬复,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏全肮。R本人自食惡果不足惜敞咧,卻給世界環(huán)境...
    茶點故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望辜腺。 院中可真熱鬧休建,春花似錦、人聲如沸评疗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽壤巷。三九已至邑彪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間胧华,已是汗流浹背寄症。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工宙彪, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人有巧。 一個月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓释漆,卻偏偏與公主長得像,于是被迫代替她去往敵國和親篮迎。 傳聞我的和親對象是個殘疾皇子男图,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,697評論 2 351

推薦閱讀更多精彩內(nèi)容