实体框架代码第一个 Objecxt 引用未设置,但存在于数据库中

本文关键字:存在 数据库 设置 代码 框架 第一个 Objecxt 引用 实体 | 更新日期: 2023-09-27 18:36:38

我正在努力解决一个直到现在我从未想到过的问题。我尝试使用 EF Code First 与 SQL CE 数据库实现应用程序。我有两个主要类,它们给了我特定的问题:

public class Session
{
    public int Id { get; set; }
    public Guid Unique { get; set; }
    public DateTime DateTime { get; set; }
    public virtual Patient Patient { get; set; }
    public virtual Test Test { get; set; }
    public virtual List<VideoExerciseResult> VideoSessionResults { get; set; }
}

public class VideoExerciseResult
{
    public int Id { get; set; }
    public Guid Unique { get; set; }        
    public string Word { get; set; }
    public bool IsAnswerCorrect { get; set; }
    public virtual Session Session { get; set; }
}

当我完成会话并保存结果 EF 时,我必须完成操作并将会话和结果保存在数据库中。我可以检查直接在.sdf文件中查找的字段,并且存在对"视频练习结果"列中Session_Id的引用。

但是在代码中,我尝试进行此操作:

private void GetSessionData()
    {
        List<VideoExerciseResult> tempList2 = new List<VideoExerciseResult>(UOW.VideoSessionsResults.GetAll());
        ListOfVideoSessionResults = new ObservableCollection<VideoExerciseResult>((tempList2.Where(ver => ver.Session.Id == SelectedSession.Id)).ToList());
    }

它给我的消息错误:

对象引用未设置为对象的实例。

事实上,如果我将鼠标悬停在 tempList2 上,一些视频练习结果对象将会话设置为 null,甚至认为.sdf文件中有一个值。

我错过了什么吗?


我将添加有关会话的代码...它基于我遵循的存储库和工作单元架构

public class EnPleinProjectUOW : IEnPleinProjectUOW, IDisposable
{
    private EnPleinProjectDbContext DbContext { get; set; }
    public IRepositoryProvider RepositoryProvider { get; set; }
    public IVideoExerciseResultRepository VideoSessionsResults
    {
        get { return GetRepo<IVideoExerciseResultRepository>(); }
    }
    public IPatientRepository Patients
    {
        get { return GetRepo<IPatientRepository>(); }
    }
    public ISessionRepository Sessions
    {
        get { return GetRepo<ISessionRepository>(); }
    }
    public ITestRepository Tests
    {
        get { return GetRepo<ITestRepository>(); }
    }
    public IImageFileRepository ImageFiles
    {
        get { return GetRepo<IImageFileRepository>(); }
    }
    // We need inverse of control
    public EnPleinProjectUOW(IRepositoryProvider repositoryProvider)
    {
        CreateDbcontext();
        repositoryProvider.DbContext = DbContext;
        RepositoryProvider = repositoryProvider;
    }
    private void CreateDbcontext()
    {
        DbContext = new EnPleinProjectDbContext();
        DbContext.Configuration.ProxyCreationEnabled = false;
        DbContext.Configuration.LazyLoadingEnabled = false;
        DbContext.Configuration.ValidateOnSaveEnabled = false;
    }
    private IRepository<T> GetStandardRepo<T>() where T : class
    {
        return RepositoryProvider.GetRepositoryForEntityType<T>();
    }
    private T GetRepo<T>() where T : class
    {
        return RepositoryProvider.GetRepository<T>();
    }
    public void Commit()
    {
        DbContext.SaveChanges();
    }
    public void Dispose()
    {
        Dispose(true);
        GC.SuppressFinalize(this);
    }
    protected virtual void Dispose(bool disposing)
    {
        if (disposing)
        {
            if (DbContext != null)
            {
                DbContext.Dispose();
            }
        }
    }       
}

这是针对常规命令的:

public class EnPleinProjectRepository<T> : IRepository<T> where T : class
{
    #region Properties
    protected DbContext DbContext { get; set; }
    protected DbSet<T> DbSet { get; set; }
    #endregion
    #region Constructor
    public EnPleinProjectRepository(DbContext dbContext)
    {
        if (dbContext == null)
            throw new ArgumentNullException("Dbcontext missing");
        DbContext = dbContext;
        DbSet = DbContext.Set<T>();
    }
    #endregion
    #region Methods
    public IQueryable<T> GetAll()
    {
        return DbSet;
    }
    public T GetById(int id)
    {
        return DbSet.Find(id);
    }
    public void Add(T entity)
    {
        DbEntityEntry dbEntityEntry = DbContext.Entry(entity);
        if (dbEntityEntry.State != System.Data.EntityState.Detached)
            dbEntityEntry.State = System.Data.EntityState.Added;
        else
        {
            DbSet.Add(entity);
        }
    }
    public void Update(T entity)
    {
        DbEntityEntry dbEntityEntry = DbContext.Entry(entity);
        if (dbEntityEntry.State == System.Data.EntityState.Detached)
        {
            DbSet.Attach(entity);
        }
        dbEntityEntry.State = System.Data.EntityState.Modified;
    }
    public void Delete(T entity)
    {
        DbEntityEntry dbEntityEntry = DbContext.Entry(entity);
        if (dbEntityEntry.State != System.Data.EntityState.Deleted)
        {
            dbEntityEntry.State = System.Data.EntityState.Deleted;
        }
        else
        {
            DbSet.Attach(entity);
            DbSet.Remove(entity);
        }
    }
    public void Delete(int id)
    {
        var entity = GetById(id);
        if (entity == null) return;
        Delete(entity);
    }
    public void DeleteAll()
    {
        foreach (T entity in DbSet)
            Delete(entity);
    }

但是我非常有信心这是有效的,因为在数据库中保存了数据并且所有引用都已保存......我不知道为什么其中一些没有被读回去......

谢谢你的回答

实体框架代码第一个 Objecxt 引用未设置,但存在于数据库中

我发现在一行中执行表达式是有效的:

ListOfVideoSessionResults = new ObservableCollection<VideoExerciseResult>(UOW.VideoSessionsResults.GetAll().Where(vsr => vsr.Session.Id == SelectedSession.Id));