0

每当我单击需要访问数据库的链接时,我在最近部署的 MVC 4 Web 应用程序中都会收到此错误:

你调用的对象是空的。

说明:执行当前 Web 请求期间发生未处理的异常。请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息。

异常详细信息:System.NullReferenceException:对象引用未设置为对象的实例。

当我通过 Visual Studio 在本地运行 mvc 应用程序并连接到这些远程数据库时,我没有收到此错误,并且凭据是正确的,因为当我“连接到数据库”时,它会正常登录并检索所有实体。我将站点发布到服务器的 FTP,因为主机没有 webdeploy 服务。

谁能解释为什么我部署的应用程序会出现数据库问题而不是我的本地版本?

更新

在我暴露这个 NullReferenceException 之前,它是一个 ReflectionTypeLoadException。不知道这是否意味着什么,但在这里:

[ReflectionTypeLoadException:无法加载一种或多种请求的类型。检索 LoaderExceptions 属性以获取更多信息。] System.Reflection.RuntimeModule.GetTypes(RuntimeModule 模块) +0 System.Reflection.RuntimeModule.GetTypes() +4 System.Reflection.Assembly.GetTypes() +61 System.Data.Entity。 ModelConfiguration.Mappers.TypeMapper.<.ctor>b_1 (Assembly a) +11 System.Linq.d _14 1.InsertRange( 2.MoveNext() +234 System.Collections.Generic.ListInt32 index, IEnumerable 1 collection) +392 System.Data.Entity.ModelConfiguration.Mappers.TypeMapper..ctor(MappingContext mappingContext) +258 System.Data.Entity.DbModelBuilder.MapTypes(EdmModel model) +114 System.Data.Entity.DbModelBuilder.Build(DbProviderManifest providerManifest, DbProviderInfo providerInfo) +112 System.Data.Entity.DbModelBuilder.Build(DbConnection providerConnection) +59 System.Data.Entity.Internal.LazyInternalContext.CreateModel(LazyInternalContext internalContext) +62 System.Data.Entity.Internal.RetryLazy2.GetValue(TInput input) +123 System.Data.Entity.Internal.LazyInternalContext .InitializeContext() +461 System.Data.Entity.Internal.InternalContext.GetEntitySetAndBaseTypeForType(Type entityType) +18 System.Data.Entity.Internal.Linq.InternalSet 1.Initialize() +52 System.Data.Entity.Internal.Linq.InternalSet1.get_InternalContext() +15 System.Data.Entity.Infrastructure.DbQuery1.System.Linq.IQueryable.get_Provider() +37 System.Linq.Queryable.Select(IQueryable1 源,表达式1 selector) +66 ProOptInteractive.Controllers.ServiceController.Index() +115 lambda_method(Closure , ControllerBase , Object[] ) +35 System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters) +14 System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary2 参数)+182 System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary 2 parameters) +27 System.Web.Mvc.Async.<>c__DisplayClass42.<BeginInvokeSynchronousActionMethod>b__41() +28 System.Web.Mvc.Async.<>c__DisplayClass81.b__7(IAsyncResult ) +10 System.Web.Mvc.Async.WrappedAsyncResult 1.End() +50 System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethod(IAsyncResult asyncResult) +32 System.Web.Mvc.Async.<>c__DisplayClass39.<BeginInvokeActionMethodWithFilters>b__33() +58 System.Web.Mvc.Async.<>c__DisplayClass4f.<InvokeActionMethodFilterAsynchronously>b__49() +225 System.Web.Mvc.Async.<>c__DisplayClass37.<BeginInvokeActionMethodWithFilters>b__36(IAsyncResult asyncResult) +10 System.Web.Mvc.Async.WrappedAsyncResult1.End() +50 System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeActionMethodWithFilters(IAsyncResult asyncResult) +34 System.Web.Mvc.Async.<>c _DisplayClass2a.b_ 20() +24 System.Web.Mvc.Async.<>c _DisplayClass25.b_ 22(IAsyncResult asyncResult) +99 System.Web.Mvc.Async.WrappedAsyncResult 1.End() +50 System.Web.Mvc.Async.AsyncControllerActionInvoker.EndInvokeAction(IAsyncResult asyncResult) +27 System.Web.Mvc.<>c__DisplayClass1d.<BeginExecuteCore>b__18(IAsyncResult asyncResult) +14 System.Web.Mvc.Async.<>c__DisplayClass4.<MakeVoidDelegate>b__3(IAsyncResult ar) +23 System.Web.Mvc.Async.WrappedAsyncResult1.End() +55 System.Web.Mvc.Controller.EndExecuteCore(IAsyncResult asyncResult) +39 System.Web.Mvc.Async.<>c_DisplayClass4.b__3(IAsyncResult ar) +23 System.Web.Mvc.Async.WrappedAsyncResult 1.End() +55 System.Web.Mvc.Controller.EndExecute(IAsyncResult asyncResult) +29 System.Web.Mvc.Controller.System.Web.Mvc.Async.IAsyncController.EndExecute(IAsyncResult asyncResult) +10 System.Web.Mvc.<>c__DisplayClass8.<BeginProcessRequest>b__3(IAsyncResult asyncResult) +25 System.Web.Mvc.Async.<>c__DisplayClass4.<MakeVoidDelegate>b__3(IAsyncResult ar) +23 System.Web.Mvc.Async.WrappedAsyncResult1.End() +55 System.Web.Mvc.MvcHandler.EndProcessRequest(IAsyncResult asyncResult) +31 System.Web.Mvc.MvcHandler.System。 Web.IHttpAsyncHandler.EndProcessRequest(IAsyncResult 结果) +9 System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +9628700 System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +155

更新

好的,我只是尝试从 Visual Studio 部署一个全新的 MVC 应用程序,并且在尝试访问模型时没有给我任何错误(我制作了一个简单的学生模型并在数据库中创建了一个新的“学生”,这在我实际的 MVC 应用程序。有什么想法吗?

4

1 回答 1

0

数据库中的表可能不存在。我现在面临同样的问题,最简单的方法是删除整个数据库并让 EF 重新创建所有内容。如果你已经有一些敏感数据,那就更棘手了。你也可以试试这些:

Database.SetInitializer(new DropCreateDatabaseIfModelChanges<YourDbContext>());
//  or you can use DropCreateDatabaseAlways<>

从这里开始:EF4 Code First create new table
或者您可以检查这个:Entity Framework 4.1 Code First not created tables

于 2013-08-16T10:39:12.963 回答