佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Asp實現的數據庫連接池功能函數分享

Asp實現的數據庫連接池功能函數分享

熱門標簽:Mysql連接數設置 服務器配置 Linux服務器 電子圍欄 阿里云 科大訊飛語音識別系統(tǒng) 銀行業(yè)務 團購網站

數據庫連接是一種關鍵的有限的昂貴的資源,這一點在多用戶的網頁應用程序中體現得尤為突出。對數據庫連接的管理能顯著影響到整個應用程序的伸縮性和健壯性,影響到程序的性能指標。數據庫連接池正是針對這個問題提出來的。數據庫連接池負責分配、管理和釋放數據庫連接,它允許應用程序重復使用一個現有的數據庫連接,而再不是重新建立一個;釋放空閑時間超過最大空閑時間的數據庫連接來避免因為沒有釋放數據庫連接而引起的數據庫連接遺漏。這項技術能明顯提高對數據庫操作的性能。

但是這項技術一般在java ,php ,.net 里面運用到,asp很少用到,因為一些企業(yè)網站根本就不需要這樣的技術。
也不是不能使用,下面就是研究出來的asp版本,能夠加快網頁的訪問速度,降低數據庫的壓力。

1.數據庫連接文件 DbPool.asp

 %
Const PoolSize = 10
Const Connstr = "Driver={SQL Server};Server=(local);UID=sa;word=555;Database=db"
 
Function GetRandString(lenth)
Dim rndstr,i
Randomize
rndstr = ""
i = 1
do while i = lenth
rndstr = rndstr  Chr(cint(((120 - 98 + 1) * Rnd )+ 97))
i = i + 1
loop
GetRandString = rndstr
End Function
 
Function CreateDbConn()
Dim DbConn,ConnKey
Set DbConn = Server.CreateObject("ADODB.Connection")
DbConn.Open Connstr
ConnKey = GetRandString(10)
DbPool.Add ConnKey,DbConn
End Function
 
 
Function GetDbConn()
Dim CurKey,Keys
If DbPool.Count > 0 Then
Keys = DbPool.Keys ' 獲取鍵名。
CurKey = Keys(0)
Response.Write "Cur DbConn Key Is : "  CurKey  "br />"
Set Conn = Server.CreateObject("ADODB.Connection")
Set Conn = DbPool(CurKey)
If Conn.State = adStateClosed Then '如果這個連接已經關閉,將其從池里注銷,再新建一個可用的連接并添加到池里
DbPool.Remove CurKey
Call CreateDbConn() '新建一個連接并添加到池里
Set GetDbConn = GetDbConn()
Else '否則的話,將其從池里注銷,然后將復制的對象返回
DbPool.Remove CurKey
Set GetDbConn = Conn
Exit Function
End If
Else
Response.Write "連接池已用完,請重新初始化應用程序"
Response.End
End if
End Function
 
Function FreeDbConn(DbConn)
DbPool.Add GetRandString(10),DbConn
End Function

2.全局文件 global.asa

object ID="DbPool" Progid="Scripting.Dictionary" Scope="Application" runat="server">/object>
!--#include file="DbPool.asp"-->
 %
Sub Application_OnStart
Dim ConnKey
For i = 1 To PoolSize '建立指定數目的數據庫連接
CreateDbConn()
Next
End Sub
 
Sub Application_OnEnd
DbPool.RemoveAll
End Sub
%>

3.測試文件 test.asp

!--#include file="DbPool.asp"-->
 %
Response.Write "Test Start:br>"
Response.Write "Current Objects count : "  DbPool.Count  "br />"
 
Set dbconn = Server.CreateObject("ADODB.Connection")
Set dbconn = GetDbConn()
Response.Write "get one connection from pool br />"
Response.Write "Current Objects count : "  DbPool.Count  "br />"
 
Set Rs = Server.CreateObject("ADODB.Recordset")
Rs.open "select * from mkdb",dbconn,1,1
Do While Not rs.eof
Response.write Rs("v_oid")  "br />"
Rs.movenext
loop
 
FreeDbConn(dbconn)
Response.Write "free one connection to pool br />"
Response.Write "Current Objects count : "  DbPool.Count  "br />"
 
%>

標簽:衢州 廣元 蚌埠 大理 棗莊 萍鄉(xiāng) 江蘇 衡水

巨人網絡通訊聲明:本文標題《Asp實現的數據庫連接池功能函數分享》,本文關鍵詞  ;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    公主岭市| 遂平县| 乌什县| 敖汉旗| 华容县| 福海县| 荔波县| 呼图壁县| 徐汇区| 稷山县| 清涧县| 嘉鱼县| 绥芬河市| 屯留县| 平武县| 汉中市| 霍山县| 临安市| 松原市| 汉川市| 兴文县| 吉林省| 南丹县| 栖霞市| 武川县| 甘谷县| 台湾省| 噶尔县| 巨野县| 于都县| 东至县| 聂拉木县| 镇平县| 定兴县| 遵义市| 寿宁县| 修文县| 杭州市| 安丘市| 石城县| 宁波市|