gpt4 book ai didi

ADO.NET之连接池技术的使用详解

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 24 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章ADO.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

最后此篇关于ADO.NET之连接池技术的使用详解的文章就讲到这里了,如果你想了解更多关于ADO.NET之连接池技术的使用详解的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com