ADO.NET之連接池技術(shù)的使用詳解
連接到數(shù)據(jù)庫服務(wù)器通常需要一定的時間,且服務(wù)器也需要一定的資源來處理連接。Web應(yīng)用程序有時處理成千上萬的連接,需要相當多的資源來處理連接。ADO.NET具有連接池的特性,連接池的功能是保留一定數(shù)量的連接,當用戶使用相同的連接字符串再次連接服務(wù)器時,ASO.NET將使用連接池中的連接而不用重新發(fā)起一次連接過程。當調(diào)用Close方法關(guān)閉連接時,ADO.NET將使用連接池中的連接而不用重新發(fā)起一次連接過程。當調(diào)用Close方法關(guān)閉連接時,連接將會返回到連接池中,下次再次調(diào)用Open方法時,將從連接池中取出一個連接使用。
數(shù)據(jù)庫連接字符串默認為啟用連接池。使用連接池可以在連接字符串中用pooling=true/false來控制,設(shè)置連接池最大值和最小值可以使用Max Pool Size=200;Min Pool Size=1; 進行控制。
下邊新建一個控制臺應(yīng)用程序來演示連接池的使用,其實我們僅僅是在Connection String中使用pooling=false/true來控制,默認是使用連接池技術(shù)的,也就是pooling=true:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient;
using System.Threading;
namespace ConsoleApplication1
{
class Program
{
private static readonly string connectionString1 = @"Data Source=.;Initial Catalog=Northwind;Integrated Security=True;pooling=true;";//默認值即為true,所以可省略pooling=true
private static readonly string connectionString2 = @"Data Source=.;Initial Catalog=Northwind;Integrated Security=True;pooling=false;";
static void Main(string[] args)
{
long startTicks1 = DateTime.Now.Ticks;
using (SqlConnection conn1 = new SqlConnection(connectionString1))
{
for (int i = 0; i < 100; i++)
{
conn1.Open();
conn1.Close();
}
}
long endTicks1 = DateTime.Now.Ticks;
long usedTicks1 = endTicks1 - startTicks1;
Console.WriteLine("Used time: " + usedTicks1);
long startTicks2 = DateTime.Now.Ticks;
using (SqlConnection conn2 = new SqlConnection(connectionString2))
{
for (int i = 0; i < 100; i++)
{
conn2.Open();
conn2.Close();
}
}
long endTicks2 = DateTime.Now.Ticks;
long usedTicks2 = endTicks2 - startTicks2;
Console.WriteLine("Used time: " + usedTicks2);
}
}
}
輸出結(jié)果:
pooling=true: 710040
pooling=false: 3100177
相關(guān)文章
在.NET使用JSON作為數(shù)據(jù)交換格式實例演示
JSON(JavaScript Object Notation)是一種輕量級輕量級的數(shù)據(jù)交換格式,并且它獨立于編程語言,接下來為大家介紹下使用JSON作為數(shù)據(jù)交換格式在.net中的應(yīng)用2013-03-03
Repeater事件OnItemCommand取得行內(nèi)控件的方法
這篇文章主要介紹了Repeater事件OnItemCommand取得行內(nèi)控件的方法,有需要的朋友可以參考一下2014-01-01

