程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> ADO.NET之連接池技術的使用詳解

ADO.NET之連接池技術的使用詳解

編輯:ASP.NET基礎

連接到數據庫服務器通常需要一定的時間,且服務器也需要一定的資源來處理連接。Web應用程序有時處理成千上萬的連接,需要相當多的資源來處理連接。ADO.NET具有連接池的特性,連接池的功能是保留一定數量的連接,當用戶使用相同的連接字符串再次連接服務器時,ASO.NET將使用連接池中的連接而不用重新發起一次連接過程。當調用Close方法關閉連接時,ADO.NET將使用連接池中的連接而不用重新發起一次連接過程。當調用Close方法關閉連接時,連接將會返回到連接池中,下次再次調用Open方法時,將從連接池中取出一個連接使用。

數據庫連接字符串默認為啟用連接池。使用連接池可以在連接字符串中用pooling=true/false來控制,設置連接池最大值和最小值可以使用Max Pool Size=200;Min Pool Size=1; 進行控制。

下邊新建一個控制台應用程序來演示連接池的使用,其實我們僅僅是在Connection String中使用pooling=false/true來控制,默認是使用連接池技術的,也就是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);

        }

 

    }

}

輸出結果:
復制代碼 代碼如下:
pooling=true: 710040
pooling=false: 3100177

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved