<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    qileilove

    blog已經轉移至github,大家請訪問 http://qaseven.github.io/

    java數據庫連接池 dbcp 的用法

      需要下commons-dbcp  commons-pool 這兩個jar包

    import org.apache.commons.dbcp.BasicDataSource;
    import org.apache.commons.dbcp.BasicDataSourceFactory;
    import java.sql.SQLException;
    import java.sql.Connection;
    import java.util.Properties;
    public class ConnectionSource {
    private static BasicDataSource dataSource = null;
    public ConnectionSource() {
    }
    public static void init() {
    if (dataSource != null) {
    try {
    dataSource.close();
    } catch (Exception e) {
    //
    }
    dataSource = null;
    }
    try {
    Properties p = new Properties();
    p.setProperty("driverClassName", "oracle.jdbc.driver.OracleDriver");
    p.setProperty("url", "jdbc:oracle:thin:@192.168.0.1:1521:testDB");
    p.setProperty("password", "scott");
    p.setProperty("username", "tiger");
    p.setProperty("maxActive", "30");
    p.setProperty("maxIdle", "10");
    p.setProperty("maxWait", "1000");
    p.setProperty("removeAbandoned", "false");
    p.setProperty("removeAbandonedTimeout", "120");
    p.setProperty("testOnBorrow", "true");
    p.setProperty("logAbandoned", "true");
    dataSource = (BasicDataSource) BasicDataSourceFactory.createDataSource(p);
    } catch (Exception e) {
    //
    }
    }
    public static synchronized Connection getConnection() throws  SQLException {
    if (dataSource == null) {
    init();
    }
    Connection conn = null;
    if (dataSource != null) {
    conn = dataSource.getConnection();
    }
    return conn;
    }
    }

      接下來,在我們的應用中,只要簡單地使用ConnectionSource.getConnection()就可以取得連接池中的數據庫連接,享受數據庫連接帶給我們的好處了。當我們使用完取得的數據庫連接后,只要簡單地使用connection.close()就可把此連接返回到連接池中,至于為什么不是直接關閉此連接,而是返回給連接池,這是因為dbcp使用委派模型來實現Connection接口了。

      在使用Properties來創建BasicDataSource時,有很多參數可以設置,比較重要的還有:

      testOnBorrow、testOnReturn、testWhileIdle,他們的意思是當是取得連接、返回連接或連接空閑時是否進行有效性驗證(即是否還和數據庫連通的),默認都為false。所以當數據庫連接因為某種原因斷掉后,再從連接池中取得的連接,實際上可能是無效的連接了,所以,為了確保取得的連接是有效的, 可以把把這些屬性設為true。當進行校驗時,需要另一個參數:validationQuery,對oracle來說,可以是:SELECT COUNT(*) FROM DUAL,實際上就是個簡單的SQL語句,驗證時,就是把這個SQL語句在數據庫上跑一下而已,如果連接正常的,當然就有結果返回了。

      還有2個參數:timeBetweenEvictionRunsMillis 和 minEvictableIdleTimeMillis, 他們兩個配合,可以持續更新連接池中的連接對象,當timeBetweenEvictionRunsMillis 大于0時,每過timeBetweenEvictionRunsMillis 時間,就會啟動一個線程,校驗連接池中閑置時間超過minEvictableIdleTimeMillis的連接對象。

    posted on 2013-09-24 10:18 順其自然EVO 閱讀(382) 評論(0)  編輯  收藏 所屬分類: 數據庫

    <2013年9月>
    25262728293031
    1234567
    891011121314
    15161718192021
    22232425262728
    293012345

    導航

    統計

    常用鏈接

    留言簿(55)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 波多野结衣中文字幕免费视频| 日韩高清在线高清免费| 亚洲一级片在线播放| 国产精品视频免费一区二区三区| jizz免费一区二区三区| 亚洲国产精品xo在线观看| 国产成人免费高清在线观看| 91视频免费观看高清观看完整| 亚洲最大在线观看| 亚洲精品国产高清不卡在线| 中国人xxxxx69免费视频| 日韩在线视频线视频免费网站| 亚洲免费在线播放| 又爽又黄无遮挡高清免费视频| 久99久精品免费视频热77| 美女视频黄频a免费观看| 亚洲午夜电影在线观看高清| 国产精品亚洲综合专区片高清久久久| 在线免费观看国产| 国产精品成人啪精品视频免费| 亚洲免费在线视频观看| 精品国产综合成人亚洲区| 日本不卡免费新一二三区| 91短视频在线免费观看| a在线视频免费观看在线视频三区| 亚洲免费视频网址| 亚洲电影免费在线观看| 亚洲第一网站男人都懂| 成人毛片18女人毛片免费| 蜜桃成人无码区免费视频网站 | 在线免费观看你懂的| 久久精品免费大片国产大片| 亚洲午夜无码久久久久小说| 久久久久亚洲精品影视| 亚洲毛片av日韩av无码| 国产精品jizz在线观看免费| 可以免费看黄视频的网站| 一区二区在线免费观看| 国内少妇偷人精品视频免费| 成人免费网站视频www| 亚洲精品久久无码av片俺去也|