【问题标题】:EF throwing NullReferenceException on SaveChanges() after updating record properties.. sometimes [duplicate]更新记录属性后,EF 在 SaveChanges() 上抛出 NullReferenceException .. 有时 [重复]
【发布时间】:2013-11-05 23:31:59
【问题描述】:

我的简化数据库:

   +----------+
   |Products  |
   +----------+
   |ProductID |
   |ProdName  |
   |Desc      |
   |BrandID   |
   |CategoryID|
   +----------+

   +----------+
   |Brands    |
   +----------+
   |BrandID   |
   |BrandName |
   |ImageID   |
   |Desc      |
   +----------+

   +----------+
   |Categories|
   +----------+
   |CategoryID|
   |CategName |
   |ImageID   |
   |Desc      |
   +----------+

   +----------+
   |Images    |
   +----------+
   |ImageID   |
   |Path      |
   +----------+

   +----------+
   |ImageLinks|
   +----------+
   |ImageID   |
   |ProductID |
   +----------+

(注意:一个产品可以有多个图片,但一个品牌/类别最多可以有一个)

在 ASP.NET 中,

   using (DBEntities db = new DBEntities()) 
   {
         Product product = db.Products.FirstOrDefault(p => p.ProductID == 1);
         if (product != null) product.Desc = "any value";
         db.SaveChanges(); //works


         Image image = db.Images.FirstOrDefault(i => i.ImageID == 1);
         if (image != null) image.Path = "any value";
         db.SaveChanges(); //works

         Brand brand = db.Brands.FirstOrDefault(b => b.BrandID == 1);
         if (brand != null) brand.Desc = "the same value as the old description";
         db.SaveChanges();  //works

         Brand brand = db.Brands.FirstOrDefault(b => b.BrandID == 1);
         if (brand != null) brand.Desc = "some new description";
         db.SaveChanges();  //throws null reference exception

         Category categ = db.Categories.FirstOrDefault(c => c.CategoryID == 1);
         if (categ != null) categ.Desc = "the same value as the old description";
         db.SaveChanges();  //works

         Category categ = db.Categories.FirstOrDefault(c => c.CategoryID == 1);
         if (categ != null) categ.Desc = "some new description";
         db.SaveChanges();  //throws null reference exception
   }

这很奇怪!

这是 SaveChanges() 抛出的 NullReferenceException 的堆栈跟踪

Object reference not set to an instance of an object.
   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 VatechWebsite.Admin.Image_Upload.UploadBtn_Click(Object sender, EventArgs e) in c:\Users\Toshiba User\Desktop\vatech\VatechWebsite\VatechWebsite\Admin\Image_Upload.aspx.cs:line 109

PS:这是实体框架5

【问题讨论】:

  • 您可以在该方法结束时调用一次SaveChanges...
  • 我也试过了,还是不行……
  • 堆栈跟踪显示异常来自 SaveChanges 内部发生的验证。默认情况下,此验证基于 DataAnnotation 属性,显然在您的情况下,与 System.Web 中的某些属性有一些交互。也许实体类或其属性中的某些属性代码中存在错误?在最坏的情况下,您可以禁用保存验证,但看看您的实体类型会很有趣。
  • 这很有趣..禁用保存验证有效,但我不确定实体类中可能存在什么样的错误..我首先使用数据库并依赖 EF 生成此代码.我所有的非 ID 列都可以为空,所以我不确定可能是什么问题
  • 确实很有趣。我以前没有见过这种情况,但我刚才搜索了一下,发现了这个以前的帖子:stackoverflow.com/questions/17136455/…。您能否确认这可以解决问题?

标签: asp.net entity-framework webforms entity-framework-5 nullreferenceexception


【解决方案1】:

正如潜水员指出的那样,问题在于我有一个与 EF 生成的实体同名的类(类别和品牌)。参考这个帖子NullReferenceException in DbContext.saveChanges()

【讨论】:

    【解决方案2】:

    我认为您分配实体模型的对象类的方式不正确。 将以下更改应用于代码中的所有实体对象,然后尝试:

    产品 product = db.Products.FirstOrDefault(p => p.ProductID == 1); /* 产品 */

    对于类别、图片和品牌也是如此。

    一切顺利。

    【讨论】:

    • 对不起,这是我在真实案例中所做的,但我复制了错误的代码。我会更新我的问题
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-09-29
    • 2021-02-26
    • 2012-02-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多