日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

數(shù)據(jù)庫連接緩沖池

 bluecrystal 2006-07-26
 數(shù)據(jù)庫連接緩沖池

一個數(shù)據(jù)庫緩沖池指的是緩存于內(nèi)存空間中的數(shù)據(jù)庫物理連接,這些數(shù)據(jù)庫連接可以被重復(fù)使用。數(shù)據(jù)庫緩沖池對于提高Java 數(shù)據(jù)庫應(yīng)用程序的性能十分重要,尤其是當這個Java 數(shù)據(jù)庫應(yīng)用程序運行于中間層服務(wù)器環(huán)境時。

數(shù)據(jù)緩沖池存在于中間層服務(wù)器環(huán)境當中,可以被不同的Java 應(yīng)用程序所調(diào)用。javax.sql.RowSet 包添加了對緩沖數(shù)據(jù)源的支持,即可以將緩沖池緩沖的數(shù)據(jù)庫連接看作是一個是實實在在的數(shù)據(jù)源服務(wù)來使用。RowSet 包提供了好幾個接口用于處理數(shù)據(jù)庫緩沖池,主要的接口有:
1、DataSource
接口:DataSource 接口的實例對象代表了存在于中間層服務(wù)器中的緩沖數(shù)據(jù)源服務(wù)。使用它可以返還數(shù)據(jù)庫緩沖池中現(xiàn)存的數(shù)據(jù)庫連接,DataSource 接口的實例對象實際上是某個JNDI 服務(wù)的提供者,在使用它之前,該JNDI 服務(wù)對象必須先在中間層服務(wù)器環(huán)境中注冊,并且和某個服務(wù)名綁定在一起,然后它才能被別的Java 應(yīng)用程序調(diào)用。
2、ConnectionPoolDataSource 接口:該接口可以用于創(chuàng)建一個被緩沖于緩沖池的數(shù)據(jù)庫物理連接,它有可能會被DataSource 接口的實例對象調(diào)用。
3、PooledConnection 接口:該接口代表被緩沖的數(shù)據(jù)庫連接,它定義了一個getConnection()方法使用這個方法可以返回java.sql.Connection 接口的實例對象。
如何使用RowSet 包定義的類和接口操作數(shù)據(jù)庫緩沖池,下面的JSP 代碼段提供了一個簡單的不完整的例子

<%

Context ctx = new InitialContext();

DataSource ds = (DataSource)ctx.lookup(“jdbc/EmployeeDB”);

// First get a Connection. Connection pooling is done

// internally by the DataSource object.

Connection con = ds.getConnection(jdbc/webDatabase” "sa” “");

// Do all the work as a single transaction (optional).

con.setAutoCommit(false);

// The actual work (queries and updates) would go here.

// Work is done using standard JDBC code as defined in the

// rest of the JDBC API.

// Commit the transaction.

con.commit();

// Close the connection. This returns the underlying physical

// database connection to the pool.

con.close();

%>

上面的JSP 代碼段的運行機理如下

1、首先程序代碼獲取初始化的JNDI 環(huán)境并且調(diào)用Context.lookup()方法從JNDI服務(wù)提供者那里獲一個DataSource 對象

2、中間層JNDI 服務(wù)提供者返回一個DataSource 對象給當前的Java 應(yīng)用程序這個DataSource 對象代表了中間層服務(wù)上現(xiàn)存的緩沖數(shù)據(jù)源

3、 應(yīng)用程序調(diào)用DataSource 對象的getConnection()方法

4、DataSource 對象的getConnection()方法被調(diào)用時中間層服務(wù)器將查詢數(shù)據(jù)庫連接緩沖池中有沒有PooledConnection 接口的實例對象這個PooledConnection對象將被用于與數(shù)據(jù)庫建立物理上的數(shù)據(jù)庫連接

5、如果在緩沖池中命中了一個PooledCoonection 對象那么連接緩沖池將簡單地更新內(nèi)部的緩沖連接隊列并將該PooledConnection 對象返回如果在緩沖池內(nèi)沒有找到現(xiàn)成的PooledConnection 對象那么ConnectionPoolDataSource 接口將會被用來產(chǎn)生一個新的PooledConnection 對象并將它返回以便應(yīng)用程序使用

6\中間層服務(wù)器調(diào)用PooledConnection 對象的getConnection()方法以便返還一個java.sql.Connection 對象給當前的Java 應(yīng)用程序

7、當中間層服務(wù)器調(diào)用PooledConnection 對象的getConnection()方法時JDBC 數(shù)據(jù)庫驅(qū)動程序?qū)?chuàng)建一個Connection 對象并且把它返回中間層服務(wù)器

8、中間層服務(wù)器將Connection 對象返回給應(yīng)用程序Java 應(yīng)用程序可以認為這個Connection 對象是一個普通的JDBC Connection 對象使用它可以和數(shù)據(jù)庫建立事實上的連接與數(shù)據(jù)庫引擎產(chǎn)生交互操作

9、當應(yīng)用程序不需要使用Connection 對象時,可以調(diào)用Connection 接口的close()法。請注意這種情況下close()方法并沒有關(guān)閉事實上的數(shù)據(jù)庫連接,僅僅是釋放了被應(yīng)用程序占用的數(shù)據(jù)庫連接,并將它還給數(shù)據(jù)庫連接緩沖池,數(shù)據(jù)庫連接緩沖池會自動將這個數(shù)據(jù)庫連接交給請求隊列中下一個的應(yīng)用程序使用。


    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多