数据库连接池的疑惑?

做了个试验:

WinForm窗体上放三个按钮,代码分别为:

string strConn1 = @"Provider=SQLOLEDB.1;Data Source=(local);Initial Catalog=Northwind;Integrated Security=SSPI";

string strConn2 = @"Data Source=(local);Initial Catalog=Northwind;Provider=SQLOLEDB.1;Integrated Security=SSPI";

// 注意:连接串strConn1 、strConn2除了属性顺序有所不同,其他都一样。

OleDbConnection conn1, conn2;

private void button1_Click(object sender, EventArgs e)
{
conn1 = new OleDbConnection(strConn1);
conn1.Open();
}

private void button2_Click(object sender, EventArgs e)
{
conn2 = new OleDbConnection(strConn2);
conn2.Open();
}

private void button3_Click(object sender, EventArgs e)
{
conn1.Close();
}

  然后打开“控制面板”/“管理工具”/“性能”,在性能查看器中添加计数 器,在“添加计数器”对话框中,选择“性能对象”为“SQLServer:General Statistics”,再在下面的列表框中选择“User Connections”,最后“添加”。然后点击工具栏中“查看报表”,可以看到:
-------------------------------------------------
SQLServer:General Statistics
User Connections 0
-------------------------------------------------
表 明当前SQLServer连接数为0。

接下来点击上述WinForm窗体上的Button1,看到:
User Connections ------1 //表明建立了一个连接

再点击Button3,看到:
User Connections ------1 //表明连接并没有被关闭,而是放回到了连接池中

最后点击Button2,仍然看到:
User Connections------1 //疑问之处!

按理最后点击Button2,应该看到:User Connections ------2 ,因为两个连接串并不完全相同。但事实上连接数却仍为1!


为什么呢? 我的分析是:点击Button3,关闭了 第一个连接,连接被放回到连接池;然后点击Button2时,系统使用了连接池中的那个连接,并没有创建新的连接,所以看到连接数仍为1。


但是,MSDN上看到,两个连接串必须完全相同(包括其中属性的顺序)时,第二个连接才会使用池中的连接。这不跟上述试验矛盾了吗?


难道 是ADO.NET 2.0 的新特性 ?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值