Java使用數據庫連接池連接Oracle數據庫

        頻繁的創建和銷燬數據庫連接即消耗系統資源又使得程序效率低下,在這種情況下,出現了使用數據庫連接池的方法,類似於線程池,初期創建一定數量的連接供應用程序使用,當使用完成後將其歸還給連接池而不是銷燬,這樣有效的提高了資源利用率,下面分享一種簡單的創建連接池的方法:

1.首先,我們新建一個maven工程,並且導入ojdbc  , dbcp  , junit三個包待用

創建工程並導包

2.然後,我們在src/main/resources目錄下創建一個文件db,properties用以存放一些配置參數等,以後更換數據庫密碼什麼的只需要改此文件而不是改動代碼。

db.properties文件代碼如下

# connection parameters
driver=oracle.jdbc.driver.OracleDriver    (數據庫驅動類)


url=jdbc:oracle:thin:@localhost:1521:xe 

//jdbc協議:數據庫子協議:主機:端口/連接的數據庫


user=system
pwd=root

#這個沒什麼說的,用戶名密碼,自己創建數據庫的時候都設置過

# datasouce parameters
initSize=1
maxSize=2

#最大連接數,這個不用管


driver的選取:


























以上就算是準備工作

下面開始敲代碼了

在src/main/java 下創建一個包,再創建一個類,名字自己取


補充兩點1.Properties類專門用來讀取properties文件
               2.Properties類本質上就是Map


編寫如下圖代碼讀取我們在db.properties文件中設置的參數,注意,這裏我們創建的是連接池,這些內容

我們只需要加載一次,所以寫在static代碼塊中


代碼:

package util;

import java.io.IOException;
import java.sql.Connection;
import java.sql.SQLException;
import java.util.Properties;

import org.apache.tomcat.dbcp.dbcp.BasicDataSource;

public class DBUtil {
    //連接池對象
    private static BasicDataSource ds;
    //加載參數
    static{
        Properties p = new Properties();
        try {
            p.load(DBUtil.class.getClassLoader().getResourceAsStream("db.properties"));
            String driver = p.getProperty("driver");
            String url = p.getProperty("url");
            String user = p.getProperty("user");
            String pwd = p.getProperty("pwd");
            String initSize = p.getProperty("initSize");
            String maxSize = p.getProperty("maxSize");
            //創建連接池
            ds = new BasicDataSource();
            //設置參數
            ds.setDriverClassName(driver);
            ds.setUrl(url);
            ds.setUsername(user);
            ds.setPassword(pwd);
            ds.setInitialSize(new Integer(initSize));
            ds.setMaxActive(new Integer(maxSize));
        } catch (IOException e) {
            e.printStackTrace();
            throw new RuntimeException("加載配置文件失敗",e);
        }
    }
    /*
     * 以上就是將配置文件裏的參數全部讀取出來,接下來就是要
     * 寫兩個方法,一個是用來創建連接的,一個關閉連接
     * */
    public static Connection getConnection() throws SQLException{
        return ds.getConnection();
    }
    
    public static void close(Connection conn){
        if (conn != null) {
            try {
                conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
                throw new RuntimeException("關閉連接失敗",e);
            }
        }
    }
}


寫完之後,基本工作就完成了,下面我們在src/test/resources下創建一個測試類來檢測我們的代碼


這裏我們使用的是Junit做單元測試

代碼:

package test;

import java.sql.Connection;
import java.sql.SQLException;

import org.junit.Test;

import util.DBUtil;

public class Testdb {
    @Test
    public void test01(){
        Connection conn = null;
        try {
            conn = DBUtil.getConnection();
            System.out.println("OK!");
        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }finally{
            DBUtil.close(conn);
        }
        
    }
}

運行上述代碼得到如圖所示的結果說明我們的代碼是正確的




並且控制檯輸出OK!


如果出現錯誤請檢查數據庫驅動類是否填寫正確,數據庫服務是否正常啓動,

第一次寫文章,純手打,不喜勿噴謝謝,請大偉大神多多指教微笑




發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章