c# – 导致的原因:“在创建模型时无法使用上下文.”?

我是MVC和实体框架的新手.

我有一个简单的Azure MVC 3 Web应用程序.我正在使用Entity Framework和Ninject,我的数据存储在sql数据库中.

每当我尝试向我的存储库发出并发请求时,我收到此错误消息.例如,一个存储库是图像标题,因此当页面加载时,如果有多个图片,它通常会失败并显示以下消息:

“在创建模型时不能使用上下文.”

这是我的连接字符串:

<add name="EfdbContext" connectionString="Data Source=.\sqlEXPRESS;Initial Catalog=Thedbname; Integrated Security=sspI; MultipleActiveResultSets=True" providerName="System.Data.sqlClient"/>

对于Ninject,当我绑定接口时,我尝试将其更改为使用InTransientScope和InRequestScope.没有不同.

this.ninjectKernel.Bind<ICaptionsRepository>().To<EFCaptionRepository>().InTransientScope();

它失败的部分在这里

Caption foundCaption = currentCaptionRepository.Captions.FirstOrDefault(a => a.ID == pictureID);

如果您需要任何其他信息以帮助找到问题,请与我们联系.

干杯!

编辑:这是堆栈跟踪

   at System.Data.Entity.Internal.LazyInternalContext.InitializeContext()
   at System.Data.Entity.Internal.InternalContext.Initialize()
   at System.Data.Entity.Internal.InternalContext.GetEntitySetAndBaseTypeForType(Type entityType)
   at System.Data.Entity.Internal.Linq.InternalSet`1.Initialize()
   at System.Data.Entity.Internal.Linq.InternalSet`1.get_InternalContext()
   at System.Data.Entity.Infrastructure.DbQuery`1.System.Linq.IQueryable.get_Provider()
   at System.Linq.Queryable.FirstOrDefault[TSource](IQueryable`1 source,Expression`1 predicate)
   at MVCProject.WebUI.Controllers.ImageController.GetimageByIDWithSize(String id) in C:\MVCProject\MVCProject\MVCProject.WebUI\Controllers\ImageController.cs:line 131
   at MVCProject.WebUI.Controllers.ImageController.Getimage(String id) in C:\MVCProject\MVCProject\MVCProject.WebUI\Controllers\ImageController.cs:line 215
   at lambda_method(Closure,ControllerBase,Object[] )
   at System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext,IDictionary`2 parameters)
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext,ActionDescriptor actionDescriptor,IDictionary`2 parameters)
   at System.Web.Mvc.ControllerActionInvoker.c__displayClass15.b__12()
   at System.Web.Mvc.ControllerActionInvoker.InvokeActionMethodFilter(IActionFilter filter,ActionExecutingContext preContext,Func`1 continuation)

解决方法

什么是底层DbContext的生活方式?我猜你的存储库依赖于db上下文,如果你的DbContext被注册为单例,这将会爆炸.如果是这种情况,请调整DbContext pr请求的范围,创建DbContext的成本很低,并且不打算作为单个实例保留.

相关文章

目录简介使用JS互操作使用ClipLazor库创建项目使用方法简单测...
目录简介快速入门安装 NuGet 包实体类User数据库类DbFactory...
本文实现一个简单的配置类,原理比较简单,适用于一些小型项...
C#中Description特性主要用于枚举和属性,方法比较简单,记录...
[TOC] # 原理简介 本文参考[C#/WPF/WinForm/程序实现软件开机...
目录简介获取 HTML 文档解析 HTML 文档测试补充:使用 CSS 选...