mysql连接 为什么不能复用

发布时间:2024-11-30 23:02

为什么手机充电时不能接电话?怕电火花。 #生活乐趣# #日常生活趣事# #日常生活笑话# #笑料连连#

注:EF连接Mysql时,连接字符串是不能包含MARS的,Mysql不支持这个特性。

ADO.NET 1.n 利用SqlDataReader读取数据,针对每个结果集需要一个独立的连接。

这些独立的链接也要占用相应的内存,在应用程序运行中还会形成高度拥挤的瓶颈效应。

ADO.NET 2.的一个新特征多数据结果集(Multiple Active Result Sets,简称MARS)

它允许在单个连接上执行多重的数据库查询或存储过程。目前只适用于Sql Server 2005

在一个Command对象上同时打开多个DataReader,即可以在sqldatareader里面嵌套sqldatareader,

如果不用MultipleActiveResultSets ,则一般报错为sqldatareader未关闭,即需要关闭了之后才能打开另一个

使用方法:在数据库链接字符串后面加上MultipleActiveResultSets=true

例如:string connstr = "server=(local);database=northwind;integrated security=true;MultipleActiveResultSets=true";

MultipleActiveResultSets可以使数据库连接复用。这样就不怕数据库的连接资源被耗尽了。使用方法很简单,只需要把它加到数据的连接字符串中即可。

例如:server=(local);Integrated Security = true;database=AdventureWorks;MultipleActiveResultSets=true;

usingSystem;usingSystem.Threading;usingSystem.Data.SqlClient;usingSystem.Configuration;namespaceConsoleApplication1

{public classExample

{public static voidMain()

{

SqlConnection sql1= new SqlConnection("server=(local);Integrated Security = true;database=AdventureWorks;");

sql1.Open();

SqlCommand comm1= newSqlCommand();

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数据库。

这就是数据库连接复用的好处了。

网址:mysql连接 为什么不能复用 https://www.yuejiaxmz.com/news/view/328517

相关内容

pdo连接mysql数据库(简洁明了)
java连接mysql错误及解决方案整合
PowerBuilder连接SQLServer失败 SQL State:‘28000’
sqlalchemy mysql配置中怎么设置utf8
浅谈mysql集群
日常工作中如何做MySQL优化?
在linux上运行mysql客户端时报错unknown variable 'basedir=/usr/local/mysql
MySql错误:mysqld: Can't create directory '/usr/local/mysql/data/
Navicat for MySQL安装及使用教程
MySQL慢查询优化

随便看看