<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇

        來源:懂視網 責編:小采 時間:2020-11-09 07:46:22
        文檔

        黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇

        黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇:lDataSource用來取代DriverManager來獲取Connection; l通過DataSource獲得Connection速度很快; l通過DataSource獲得的Connection都是已經被包裹過的(不是 驅動原來的連接),他的close方法已經被修改。 l一般DataSource內部會用一個連接
        推薦度:
        導讀黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇:lDataSource用來取代DriverManager來獲取Connection; l通過DataSource獲得Connection速度很快; l通過DataSource獲得的Connection都是已經被包裹過的(不是 驅動原來的連接),他的close方法已經被修改。 l一般DataSource內部會用一個連接

        lDataSource用來取代DriverManager來獲取Connection; l通過DataSource獲得Connection速度很快; l通過DataSource獲得的Connection都是已經被包裹過的(不是 驅動原來的連接),他的close方法已經被修改。 l一般DataSource內部會用一個連接池來緩存Connection

        lDataSource用來取代DriverManager來獲取Connection;

        l通過DataSource獲得Connection速度很快;

        l通過DataSource獲得的Connection都是已經被包裹過的(不是
        驅動原來的連接),他的close方法已經被修改。

        l一般DataSource內部會用一個連接池來緩存Connection,這樣

        可以大幅度提高數據庫的訪問速度;

        l連接池可以理解成一個能夠存放Connection的Collection;

        l我們的程序只和DataSource打交道,不會直接訪問連接池;

        使用DBCP步驟如下,三步:
        l使用DBCP必須用的三個包:

        commons-dbcp-1.2.1.jar,

        commons-pool-1.2.jar,

        commons-collections-3.1.jar。

        l配置參數。
        lJavaAPI:BasicDataSourceFactory.createDataSource(

        properties);

        2.dbcpconfig.properties配置文件內容:

        #連接設置
        driverClassName=com.mysql.jdbc.Driver
        url=jdbc:mysql://localhost:3306/jdbc
        username=root
        password=root

        #
        initialSize=10

        #最大連接數量
        maxActive=50

        #
        maxIdle=20

        #
        minIdle=5

        #
        maxWait=60000

        #JDBC驅動建立連接時附帶的連接屬性屬性的格式必須為這樣:[屬性名=property;]
        #注意:"user" 與 "password" 兩個屬性會被明確地傳遞,因此這里不需要包含他們。
        connectionProperties=useUnicode=true;characterEncoding=gbk

        #指定由連接池所創建的連接的自動提交(auto-commit)狀態。
        defaultAutoCommit=true

        #driver default 指定由連接池所創建的連接的只讀(read-only)狀態。
        #如果沒有設置該值,則“setReadOnly”方法將不被調用。(某些驅動并不支持只讀模式,如:Informix)
        defaultReadOnly=

        #driver default 指定由連接池所創建的連接的事務級別(TransactionIsolation)。
        #可用值為下列之一:(詳情可見javadoc。)NONE,READ_UNCOMMITTED, READ_COMMITTED, REPEATABLE_READ, SERIALIZABLE
        defaultTransactionIsolation=READ_UNCOMMITTED

        3.不需要再寫數據源,直接用

        public final class JdbcUtils {
        
        	private static DataSource myDataSource = null;
        
        	private JdbcUtils() {
        	}
        
        	static {
        	try {
        	Class.forName("com.mysql.jdbc.Driver");
        	// myDataSource = new MyDataSource2();
        	Properties prop = new Properties();
        	// prop.setProperty("driverClassName", "com.mysql.jdbc.Driver");
        	// prop.setProperty("user", "user");
        
        	InputStream is = JdbcUtils.class.getClassLoader()
        	.getResourceAsStream("dbcpconfig.properties");
        	prop.load(is);
        	myDataSource = BasicDataSourceFactory.createDataSource(prop);//創建數據源,一句代碼就完成
        	} catch (Exception e) {
        	throw new ExceptionInInitializerError(e);
        	}
        	}
        
        	public static DataSource getDataSource() {
        	return myDataSource;
        	}
        
        	public static Connection getConnection() throws SQLException {
        	// return DriverManager.getConnection(url, user, password);
        	return myDataSource.getConnection();
        	}
        
        	public static void free(ResultSet rs, Statement st, Connection conn) {
        	try {
        	if (rs != null)
        	rs.close();
        	} catch (SQLException e) {
        	e.printStackTrace();
        	} finally {
        	try {
        	if (st != null)
        	st.close();
        	} catch (SQLException e) {
        	e.printStackTrace();
        	} finally {
        	if (conn != null)
        	try {
        	conn.close();
        	// myDataSource.free(conn);
        	} catch (Exception e) {
        	e.printStackTrace();
        	}
        	}
        	}
        	}
        }

        4.測試

        public static void main(String[] args) throws Exception {

        for (int i = 0; i < 10; i++) {

        Connection conn = JdbcUtils.getConnection();

        System.out.println(conn);

        JdbcUtils.free(null, null, conn);

        }

        }

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇

        黑馬程序員JDBC_如何使用開源項目DBCP(實際項目中常用)(李勇:lDataSource用來取代DriverManager來獲取Connection; l通過DataSource獲得Connection速度很快; l通過DataSource獲得的Connection都是已經被包裹過的(不是 驅動原來的連接),他的close方法已經被修改。 l一般DataSource內部會用一個連接
        推薦度:
        標簽: 使用 如何 程序員
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 无码精品国产一区二区三区免费 | 婷婷综合缴情亚洲狠狠尤物| 亚洲美女视频网址| 一级毛片在线免费看| 亚洲精品福利视频| 84pao强力永久免费高清| 久久丫精品国产亚洲av不卡 | a级片免费观看视频| 亚洲精品自产拍在线观看| 久久99精品免费一区二区| 亚洲线精品一区二区三区影音先锋| v片免费在线观看| 国产亚洲综合成人91精品| 嫩草成人永久免费观看| 亚洲一区二区三区首页| 中文字幕av无码无卡免费| 亚洲AV无码专区在线观看成人| 国产午夜免费福利红片| 中文在线免费不卡视频| 亚洲美女视频免费| 波多野结衣久久高清免费| 四虎国产精品永免费| 亚洲国产AV无码专区亚洲AV| 1000部免费啪啪十八未年禁止观看 | 亚洲av日韩精品久久久久久a| vvvv99日韩精品亚洲| 免费成人高清在线视频| 亚洲免费闲人蜜桃| 免费在线观看中文字幕| 日韩av无码免费播放| 亚洲香蕉在线观看| 亚洲色偷偷综合亚洲AV伊人| 久久久久国产精品免费网站| 亚洲国产av美女网站| 国产一级做a爱免费视频| 污污网站免费观看| 亚洲精品无码你懂的| 亚洲女初尝黑人巨高清| 免费看国产精品3a黄的视频| 亚洲一区二区三区免费| 亚洲愉拍一区二区三区|