使用 C#、.NET 4.5.2、Entity Framework 6.1.3 和 System.Linq 我遇到了一个令人困惑的异常。异常本身似乎不包含有用的信息来确定引发该异常的原因。
执行以下代码行会导致 NullReferenceException:dbCtx.Customers.ToList();
但是,以下行运行无异常并返回正确的结果:(dbCtx.Customers).ToList();
首先运行括号括起来的表达式将允许两种形式无异常地执行:
var result1 = (dbCtx.Customers).ToList();
var result2 = dbCtx.Customers.ToList();
我还想指出,添加实体按预期工作:
dbCtx.Customers.Add(new Customer() { Enabled = true, Name = "Test" });
客户实体类:
public sealed class Customer : BaseEntity
{
public bool Enabled { get; set; }
[Required]
public string Name { get; set; }
}
基础实体类:
public abstract class BaseEntity
{
[Key]
[DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]
public int Id { get; set; }
}
DbContext 类:
public class MyDbContext : DbContext
{
public MyDbContext() : base(@"Server=.\SQLExpress;Database=MyDatabase;Trusted_Connection=Yes;")
{
Configuration.LazyLoadingEnabled = true;
}
public virtual DbSet<Customer> Customers { get; set; }
}
什么可能导致这种行为?
EDIT:当调用 .ToList()、.Count() 等方法时,任何实体都会出现此问题。
异常详细信息:
System.NullReferenceException occurred
HResult=0x80004003
Message=Object reference not set to an instance of an object.
Source=EntityFramework
StackTrace:
at System.Data.Entity.Internal.Linq.InternalSet`1.get_Expression()
at System.Data.Entity.Infrastructure.DbQuery`1.System.Linq.IQueryable.get_Expression()
at MyProjTests.Test1.Test(MyDbContext dbCtx) in E:\ProgrammingProjects\WorkInProgress\MyProjRoot\MyProjTests\Test1.cs:line 51
at MyProjTests.Test1.TestMethod1() in E:\ProgrammingProjects\WorkInProgress\MyProjRoot\MyProjTests\Test1.cs:line 43
EDIT 2:
经过实验后,我将其范围缩小到调用dbCtx.Database.CompatibleWithModel(bool)
。所提供的论点是真还是假都没有区别。当我将其注释掉时,代码中稍后不会引发 NullReferenceException 。我不知道why。呼唤dbCtx.Database.Exists()
工作正常。
此外,dbCtx.Database.Initialize(false);
也可靠地产生错误(不是在调用站点,而是在 xyz.ToList() 上)。