实体框架代码第一个 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);
}
但是我非常有信心这是有效的,因为在数据库中保存了数据并且所有引用都已保存......我不知道为什么其中一些没有被读回去......
谢谢你的回答
我发现在一行中执行表达式是有效的:
ListOfVideoSessionResults = new ObservableCollection<VideoExerciseResult>(UOW.VideoSessionsResults.GetAll().Where(vsr => vsr.Session.Id == SelectedSession.Id));