成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

剖析案例ADO.NET連接測試

開發 后端
文章就溢出做出了一個ADO.NET連接測試,測試的示例應用程序包括使用 DataAdapter 來返回行的例程,希望對大家有幫助。

學習ADO.NET時,你可能會遇到溢出問題,這里將介紹一個方法ADO.NET連接測試,在這里拿出來和大家分享一下。為了對孤立連接和發生溢出的ADO.NET連接測試,我編寫了一個 Web 窗體的示例應用程序。此應用程序使用的方法與您通常用于從查詢返回數據的方法相同。(您可以在 http://www.sqlmag.com 上下載此代碼的 WinForms 版本。)

#T#我使用了清單 1 中的代碼來打開和關閉到 Web 窗體應用程序的連接。標注 A 中的例程針對 110 個新的 SqlConnection 對象創建、打開和執行查詢 — 比默認的池大小多 10 個連接。您必須在離開該例程之前關閉和放棄所有這些連接。如果不這樣做,SqlConnection 對象將連同關聯的池連接一起被孤立。ADO.NET 池機制 (aka the pooler) 關閉數據庫連接,但不關閉池連接。我將連接池大小設置為 10,以便使該程序更快地失敗 — 如果該程序會失敗的話。通常,10 個連接對于一個運行速度象這個查詢一樣快的查詢來說已經足夠了。許多開發人員運行著忙碌的 Web 站點,這些 Web 站點使用不到五個連接來處理每天的幾十萬次點擊。

標注 A 中的例程創建 SqlConnection 對象和 SqlCommand 對象,設置 CommandText,并打開連接。然后,標注 B 中的代碼確定執行 DataReader 時是否使用 CommandBehavior.CloseConnection,這取決于用戶在 Web 窗體上選擇了哪些 CheckBox 控件。

在標注 C 的代碼中,我指定是否將 DataReader 行集綁定到 DataGrid,或者是否在整個行集中進行循環。標注 C 的代碼測試當您到達通過 DataReader 從數據提供程序傳遞回來的行集的末尾時會發生什么事情。

現在,我使用標注 D 中的代碼來指定是手工關閉連接還是讓某個其他操作(例如,數據綁定)來完成這項工作。坦白地說,以手工方式關閉連接通常是最安全的,因此,您可以肯定連接不會被孤立。

如果代碼成功地運行到這一步,說明我已經成功地打開和關閉了 110 個連接。不過,如果出了問題,標注 E 的代碼中的異常處理程序會將異常(通常是 Timeout)作為 InvalidOperationException 捕獲,該異常是連接池已滿時 ADO.NET 的響應方式。

匯總了各個選項使例程成功運行或失敗的方式。請注意,如果您不設置 CommandBehavior.CloseConnection 選項,您的操作最終會失敗 — 即使在使用綁定控件的情況下也是如此。即使您使用該選項,但如果您沒有使用復雜的綁定控件,或者沒有手工關閉 SqlDataAdapter 或 SqlConnection,該進程仍然會失敗。

當我結束了這些示例應用程序的運行后,我已經生成了 1000 多個以上的池連接 — 所有連接均處于孤立狀態。雖然“SQL Server 用戶連接”計數為 0,但留下大約 40 個連接池。在我重新引導系統之前,孤立的池不會消失。

我用于此測試的示例應用程序包括使用 DataAdapter 來返回行的例程。除非您手工管理連接,否則,DataAdapter 將正確地打開和關閉 SqlConnection 對象,因此,您不太可能遇到孤立的池連接。不過,如果您的應用程序同時使用 DataReader 和 DataAdapter,您可能會發現,如果某個連接與一個未關閉的 DataReader 相關聯,則 DataAdapter 無法針對該連接運行查詢。以上就是我做的一個關于ADO.NET連接測試,希望對大家有幫助。


 

責任編輯:田樹 來源: 博客
相關推薦

2009-11-13 13:11:37

ADO.NET連接池

2009-11-04 11:40:38

ADO.NET Dat

2009-11-12 10:15:37

ADO.NET使用

2009-09-09 10:23:59

ADO.NET連接

2009-11-13 13:35:54

ADO.NET數據服務

2009-11-12 14:26:34

ADO.NET執行事務

2009-12-23 16:05:47

ADO.NET錯誤

2009-12-28 15:32:04

ADO.NET構造

2009-12-21 11:18:09

ADO.NET體系結構

2009-11-12 09:25:21

ADO.NET連接池

2009-11-12 10:53:57

ADO.NET連接My

2009-12-30 16:58:43

ADO.NET

2009-11-12 11:38:03

ADO.NET連接事件

2009-12-25 10:25:59

2009-12-21 17:02:19

ADO.NET Sql

2009-11-04 14:54:42

ADO.NET與Pow

2009-11-03 16:27:43

ADO.NET Ent

2009-07-20 14:03:43

Ado.net連接池

2009-12-23 17:21:31

ADO.NET團隊

2009-12-21 14:14:08

ADO.NET類文件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日韩精品一区二区三区四区 | 拍戏被cao翻了h承欢 | 欧美一区久久 | 久久精品一区二区三区四区 | 亚洲综合色视频在线观看 | 亚洲不卡在线观看 | 国产精品久久久久久久午夜 | 91久久精品视频 | 天天爽天天操 | av在线一区二区三区 | 午夜精品在线 | 国产日韩一区二区三区 | h视频免费在线观看 | 日韩三级在线 | 亚洲精品一二三区 | 亚洲国产中文在线 | 欧美99久久精品乱码影视 | 国产精品色哟哟网站 | 日韩欧美视频在线 | 亚洲精品福利视频 | av中文字幕在线播放 | 91亚洲精品久久久电影 | 91av视频在线播放 | 亚洲视频一区在线观看 | 日日干日日 | 久久精片 | 国产精品日韩欧美一区二区 | 播放一级毛片 | 精品国产色 | 久久久久中文字幕 | 91国内产香蕉 | 日韩欧美一区在线 | 日韩一级黄色毛片 | 久久91| 久久精品亚洲成在人线av网址 | 黄色一级网 | 日韩欧美在线一区 | 日日摸天天添天天添破 | 欧美综合网 | 国产在线中文字幕 | 四色永久|