自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

三分鐘讓你了解什么是ADO.NET連接池

開發(fā) 后端
這里介紹了什么是ADO.NET連接池,連接池是Data Provider提供的一個(gè)機(jī)制,使得應(yīng)用程序使用的連接保存在連接池里而避免每次都要完成建立/關(guān)閉連接的完整過程。

ADO.NET經(jīng)過長時(shí)間的發(fā)展,很多用戶都很了解ADO.NET了,這里我發(fā)表一下個(gè)人理解,和大家討論討論。數(shù)據(jù)庫連接,對于以數(shù)據(jù)庫做數(shù)據(jù)存儲(chǔ)基石的應(yīng)用系統(tǒng)來說,數(shù)據(jù)庫連接是整個(gè)系統(tǒng)中最珍貴的資源之一。數(shù)據(jù)庫連接池是為了更有效地利用數(shù)據(jù)庫連接的最重要措施。它對于一個(gè)大型的應(yīng)用系統(tǒng)的性能至關(guān)重要,特別是Web應(yīng)用。ADO.NET Data Provider(以下簡稱Data Provider)會(huì)幫我們管理連接池,所以有人說使用連接池就像游兒童池一樣輕松。但并不是說有了Data Provider程序員就萬事無憂的,不正確地使用ADO.NET連接池可能導(dǎo)致你的應(yīng)用在池里淹死。筆者希望通過本文能讓讀者徹底明白連接池的重要性以及能根據(jù)實(shí)際情況正確配置連接池的參數(shù),明白實(shí)際應(yīng)用中出現(xiàn)的連接泄漏、“死連接”等異常情況和應(yīng)對方法,讓應(yīng)用輕松暢游連接池。本文主要介紹ADO.NET連接池。

什么是ADO.NET連接池

#T#連接池是Data Provider提供的一個(gè)機(jī)制,使得應(yīng)用程序使用的連接保存在連接池里而避免每次都要完成建立/關(guān)閉連接的完整過程。要理解連接池,先要理解程序里 SqlConnection.Open()、SqlConnection.Close()和打開/關(guān)閉一個(gè)“物理連接”的關(guān)系。 Data Provider在收到連接請求時(shí)建立連接的完整過程是:先連接池里建立新的連接(即“邏輯連接”),然后建立該“邏輯連接”對應(yīng)的“物理連接”。建立 “邏輯連接”一定伴隨著建立“物理連接”。Data Provider關(guān)閉一個(gè)連接的完整過程是先關(guān)閉“邏輯連接”對應(yīng)的“物理連接”然后銷毀“邏輯連接”。

銷毀“邏輯連接”一定伴隨著關(guān)閉“物理連接”。 SqlConnection.Open()是向Data Provider請求一個(gè)連接,Data Provider不一定需要完成建立連接的完整過程,可能只需要從連接池里取出一個(gè)可用的連接就可以;SqlConnection.Close()是請求關(guān)閉一個(gè)連接,Data Provider不一定需要完成關(guān)閉連接的完整過程,可能只需要把連接釋放回連接池就可以。

下面以一個(gè)例子來說明。本文例子都使用Console Application。我們使用操作系統(tǒng)的性能監(jiān)視器來比較使用連接池與否,數(shù)據(jù)庫的“物理連接”數(shù)量的不同。因?yàn)樾阅鼙O(jiān)視器至少每一秒采集一次數(shù)據(jù),為方便觀察效果,代碼中Open和Close連接后都Sleep一秒。

  1. SqlConnection con = new SqlConnection("server = .;  
  2.  
  3. database = northwind;pooling = false;trusted_connection = true");  
  4.  
  5. for(int i = 0;i < 10;i++)  
  6. {  
  7. try  
  8. {  
  9. con.Open();  
  10. System.Threading.Thread.Sleep(1000);  
  11. }  
  12. catch(Exception e){Console.WriteLine(e.Message);}  
  13. finally  
  14. {  
  15. con.Close();  
  16. System.Threading.Thread.Sleep(1000);  
  17. }  
  18. }  
責(zé)任編輯:田樹 來源: 博客
相關(guān)推薦

2009-10-29 11:39:52

ADO.NET連接池

2009-11-12 09:16:15

ADO.NET數(shù)據(jù)庫連

2009-11-09 12:55:43

WCF事務(wù)

2020-06-29 07:42:20

邊緣計(jì)算云計(jì)算技術(shù)

2009-11-10 16:05:21

VB.NET格式化

2020-03-08 16:45:58

數(shù)據(jù)挖掘學(xué)習(xí)數(shù)據(jù)量

2009-12-30 16:26:12

ADO.NET連接池

2019-01-03 14:54:58

虛擬化平臺管理員

2009-11-03 16:51:04

ADO.NET連接池觀

2020-07-21 07:42:29

數(shù)據(jù)庫信息技術(shù)

2024-02-22 07:37:37

對象JVM內(nèi)存

2022-03-29 09:18:55

區(qū)塊鏈

2009-12-23 09:01:15

ADO.NET連接池

2009-11-13 13:11:37

ADO.NET連接池

2024-05-16 11:13:16

Helm工具release

2024-12-18 10:24:59

代理技術(shù)JDK動(dòng)態(tài)代理

2009-12-23 14:53:28

ADO.NET連接池

2009-11-12 09:25:21

ADO.NET連接池

2009-11-11 14:04:14

ADO.NET連接池

2010-01-05 10:11:23

ADO.NET連接池
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號