数据库连接复用 MultipleActiveResultSets=true
2011-08-03 11:04
387 查看
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数据库。
这就是数据库连接复用的好处了。
关于数据库连接字符串的其它用法,参见:
例如: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数据库。
这就是数据库连接复用的好处了。
关于数据库连接字符串的其它用法,参见:
相关文章推荐
- 使用MultipleActiveResultSets复用Sql Server 2008数据库连接
- 使用MultipleActiveResultSets复用Sql Server 2008数据库连接
- 使用MultipleActiveResultSets复用Sql Server 2008数据库连接
- 数据库链接字符串中的细节(integrated security=true;MultipleActiveResultSets=true)
- 【转】SQLServer连接字符串配置:MultipleActiveResultSets
- Hibernate连接数据库超时设置autoReconnect=true
- 连接数据库超时设置autoReconnect=true
- 连接数据库超时设置autoReconnect=true
- 数据库连接超时,自动关闭 was active for 315435 milliseconds and has been removed automaticaly
- NET连接数据库字符串密码丢失的解决方法(persist security info=true;)
- mysql5 数据库连接丢失问题,autoReconnect=true不起作用
- MultipleActiveResultSets
- Hibernate连接数据库超时设置autoReconnect=true
- 连接数据库超时设置autoReconnect=true
- JDBC获得数据库连接时写在URL上的?useUnicode=true&characterEncoding=utf-8的意义
- 使用Hibernate + MYSQL数据库问题(Hibernate连接数据库超时设置autoReconnect=true)
- Hibernate连接数据库超时设置autoReconnect=true
- .NET连接数据库字符串密码丢失的解决方法(persist security info=true;)
- 连接数据库超时设置autoReconnect=true(mysql5以上的,设置autoReconnect=true 是无效的 只有4.x版本,起作用)