c# – .NET 4.0实体框架超时已过期[已关闭]

前端之家收集整理的这篇文章主要介绍了c# – .NET 4.0实体框架超时已过期[已关闭]前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用MVC3,.NET框架4.0和实体框架开发一个ASP.NET网站.当我运行应用程序并执行一个简单的选择sql Server 2005数据库时,我得到以下错误

“抛出一个System.Data.sqlClient.sqlException:”超时过期.在完成操作或服务器之前经过的超时时间没有响应.“

这是事情.我尝试从管理工作室登录并执行相同的查询,它的工作.我开发了一个使用.NET Framework 4.0和实体框架执行完全相同的查询的小型控制台应用程序,并返回了我需要的信息.我甚至从使用Entity框架切换到ADO.NET类(sqlConnection和sqlCommand),当从sqlCommand实例执行select时,我得到完全相同的错误.

当我使用实体框架创建模型时,我能够从向导连接到数据库,并且工作正常.我创建了所有的类,没有任何问题.

请不要告诉我解决方案是增加任何超时,因为查询真的很小(20个记录的顶部),正如我之前说的,使用相同的技术,甚至与我相同的代码从控制台应用程序运行它下面.

这是代码给我的问题:

MLIBEntities dbMLIB = new MLIBEntities();

var searchResults = (from s in dbMLIB.Sets
                     where s.setmap1.StartsWith(accountNumber)
                     select s);

return searchResults.ToList();

运行searchResults.ToList()时抛出异常.

这是实体类使用的我的连接字符串.我确定它使用连接字符串,因为我修改它与语法错误,并被检测到.

<connectionStrings>
    <add name="MLIBEntities" connectionString="Metadata=res://*/Models.MlibDBModel.csdl|res://*/Models.MlibDBModel.ssdl|res://*/Models.MlibDBModel.msl;provider=System.Data.sqlClient;provider connection string=&quot;Data Source=HERPADERP;Initial Catalog=MLIB;Integrated Security=True;MultipleActiveResultSets=True;Connect Timeout=200&quot;" providerName="System.Data.EntityClient" />
</connectionStrings>

我猜这是MVC Web应用程序中的一个配置问题,或者我只是在Web.config文件中遗漏了一些东西.有人有这个问题吗?我知道这真的很奇怪.

感谢您的帮助.我真的很想念

最后一件事.我运行了sql分析器,似乎这个查询从来没有让它到数据库服务器.任何想法为什么会发生这种情况?

解决方法

我有同样的问题,另一个也出现在后面,与MSsql无关.要解决第一个问题(运行查询花费的时间太长),我更改了command.CommandTimeout来使用较大的数字(默认为30).出现的另一个问题是当我使用计划任务来运行这个应用程序 – 在20分钟之后会抛出错误

“Thread was being aborted”

查看日志错误后,应用程序池也有超时,默认值为20分钟.

猜你在找的C#相关文章