MultipleActiveResultSets可以使数据库连接复用。这样就不怕数据库的连接资源被耗尽了。使用方法很简单,只需要把它加到数据的连接字符串中即可。
例如:server=(local);Integrated Security = true;database=AdventureWorks;MultipleActiveResultSets=true;
测试用例:
using System; using System.Threading; using System.Data.SqlClient; using System.Configuration; namespace ConsoleApplication1 { public class Example { public static void Main() { SqlConnection sql1 = new SqlConnection("server=(local);Integrated Security = true;database=AdventureWorks;"); sql1.Open(); SqlCommand comm1 = new SqlCommand(); comm1.CommandText = "select 1"; comm1.CommandType = System.Data.CommandType.Text; comm1.Connection = sql1; comm1.ExecuteNonQuery(); sql1.Close(); Console.ReadLine(); } } }
编译后,打开bin\debug\ConsoleApplication1.exe。
在SQL Server 2008 Management Studio中打开一个新窗口,输入sp_who
按F5执行,可以发现已经有一个用户连接到AdventureWorks数据库了。
再打开一个ConsoleApplication1.exe,发现又会多一个用户连接到AdventureWorks数据库。
现在把程序的连接字符串改为server=(local);Integrated Security = true;database=AdventureWorks;MultipleActiveResultSets=true;
按上面的顺序执行,发现不管打开多少个ConsoleApplication1.exe,数据库中没有用户或只有一个用户连接着AdventureWorks数据库。
这就是数据库连接复用的好处了。
关于数据库连接字符串的其它用法,参见:
http://blog.youkuaiyun.com/tjvictor/archive/2009/03/19/4004277.aspx
本文介绍如何通过设置MultipleActiveResultSets参数实现数据库连接复用,避免数据库连接资源耗尽。通过一个C#示例展示了其具体应用,并对比开启前后的连接情况。
2万+

被折叠的 条评论
为什么被折叠?



