免费视频淫片aa毛片_日韩高清在线亚洲专区vr_日韩大片免费观看视频播放_亚洲欧美国产精品完整版

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書(shū)等14項(xiàng)超值服

開(kāi)通VIP
數(shù)據(jù)庫(kù)連接緩沖池
 數(shù)據(jù)庫(kù)連接緩沖池

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

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

<%

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 代碼段的運(yùn)行機(jī)理如下

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

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

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

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

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

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

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

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

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


本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
數(shù)據(jù)庫(kù)連接池的基本原理
Data Source與數(shù)據(jù)庫(kù)連接池簡(jiǎn)介 JDBC簡(jiǎn)介(八)
Mybatis數(shù)據(jù)源結(jié)構(gòu)解析之連接池
連接數(shù)據(jù)庫(kù)
Mybatis深入之獲取數(shù)據(jù)庫(kù)連接
《深入了解mybatis原理》 Mybatis數(shù)據(jù)源與連接池
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服