NullReferenceException в DbContext.saveChanges()

Взяв мои самые первые babysteps с Entity Framework 5.0, я столкнулся с исключением самого первого созданного мной Entity.

Обратите внимание, что каждая таблица, созданная после этого, прекрасно работает. Также обратите внимание, что я предпринял обычные шаги по восстановлению базы данных и / или перезапуску Visual Studio IDE.

Используя Model-First, я создал тривиальную таблицу под названием Contacts, определяется как

  <EntityType Name="Contacts">
    <Key>
      <PropertyRef Name="ContactID" />
    </Key>
    <Property Name="ContactID" Type="int" StoreGeneratedPattern="Identity" Nullable="false" />
    <Property Name="Name" Type="nvarchar(max)" Nullable="false" />
  </EntityType>

Затем я попытался запустить следующий код (из Page_Load страницы ASP.NET)

            var contact = new DataContext.Contact { Name = aName };

            context.Contacts.Add(contact);
            context.SaveChanges();

(с именем!= ноль)

Исключение:

System.NullReferenceException was unhandled by user code
  HResult=-2147467261
  Message=Object reference not set to an instance of an object.
  Source=System.Web
  StackTrace:
       at System.Web.UI.ParseChildrenAttribute.GetHashCode()
       at System.Collections.Generic.ObjectEqualityComparer`1.GetHashCode(T obj)
       at System.Collections.Generic.HashSet`1.InternalGetHashCode(T item)
       at System.Collections.Generic.HashSet`1.AddIfNotPresent(T value)
       at System.Collections.Generic.HashSet`1.UnionWith(IEnumerable`1 other)
       at System.Collections.Generic.HashSet`1..ctor(IEnumerable`1 collection, IEqualityComparer`1 comparer)
       at System.Collections.Generic.HashSet`1..ctor(IEnumerable`1 collection)
       at System.Data.Entity.ModelConfiguration.Utilities.AttributeProvider.GetAttributes(Type type)
       at System.Data.Entity.ModelConfiguration.Utilities.AttributeProvider.GetAttributes(PropertyInfo propertyInfo)
       at System.Data.Entity.Internal.Validation.EntityValidatorBuilder.BuildPropertyValidator(PropertyInfo clrProperty)
       at System.Data.Entity.Internal.Validation.EntityValidatorBuilder.BuildValidatorsForProperties(IEnumerable`1 clrProperties, IEnumerable`1 edmProperties, IEnumerable`1 navigationProperties)
       at System.Data.Entity.Internal.Validation.EntityValidatorBuilder.BuildTypeValidator[T](Type clrType, IEnumerable`1 edmProperties, IEnumerable`1 navigationProperties, Func`3 validatorFactoryFunc)
       at System.Data.Entity.Internal.Validation.EntityValidatorBuilder.BuildEntityValidator(InternalEntityEntry entityEntry)
       at System.Data.Entity.Internal.Validation.ValidationProvider.GetEntityValidator(InternalEntityEntry entityEntry)
       at System.Data.Entity.Internal.InternalEntityEntry.GetValidationResult(IDictionary`2 items)
       at System.Data.Entity.DbContext.ValidateEntity(DbEntityEntry entityEntry, IDictionary`2 items)
       at System.Data.Entity.DbContext.GetValidationErrors()
       at System.Data.Entity.Internal.InternalContext.SaveChanges()
       at System.Data.Entity.Internal.LazyInternalContext.SaveChanges()
       at System.Data.Entity.DbContext.SaveChanges()
       at Contactisch._Default.AddContact(String aName) in c:\Projects\Contactisch\Contactisch\Contactisch\Default.aspx.cs:line 32
       at Contactisch._Default.Page_Load(Object sender, EventArgs e) in c:\Projects\Contactisch\Contactisch\Contactisch\Default.aspx.cs:line 14
       at System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e)
       at System.Web.UI.Control.OnLoad(EventArgs e)
       at System.Web.UI.Control.LoadRecursive()
       at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
  InnerException: 

Может кто-нибудь объяснить причину этого исключения? Особенно, что делает этот вызов ParseChildrenAttribute.GetHashCode?

Я нашел здесь кого-то, кто сталкивался с той же проблемой, но не получил удовлетворительного объяснения

2 ответа

Решение

Задача решена.

Причина была немного глупой. Я использовал по умолчанию ASP.NET Web Forms Application проект от VS Web Express для выполнения моего тестирования. Этот проект содержит веб-форму с именем Contact.aspx, поэтому он уже включает частичный класс Contact в том же пространстве имен, что и моя сущность Contact.

Понятно, что это не очень хорошо с Entity Framework, что привело к довольно неясной ошибке выше. Удаление страницы aspx решило проблему.

Это происходит, когда вы создаете веб-страницу ASP.NET с тем же именем, что и таблица в вашей базе данных, после генерации классов edmx и EF из вашей базы данных Visual Studio поместит их в пространство имен по умолчанию для вашего проекта, что приведет к конфликту с сгенерированным частичный класс файла.aspx.cs веб-страниц

Вам не нужно удалять или переименовывать файл.aspx вашей веб-страницы, просто измените имя частично открытого класса, объявленного в коде страниц (myPage.aspx.cs), и соответствующим образом измените свойство Inherits страницы, как показано ниже.

<%@Page Title="MyPage" ... Inherts="namespace.newClassName" >

В качестве альтернативы вы всегда можете объявить свои веб-страницы в другом пространстве имен.

Другие вопросы по тегам