gpt4 book ai didi

c# - 使用通用存储库更新实体失败

转载 作者:太空宇宙 更新时间:2023-11-03 21:57:27 24 4
gpt4 key购买 nike

我有一个通用存储库:

    public class GenericRepository<TEntity> : AbstractRepository<TEntity>, IRepository<TEntity> where TEntity : class
{
private DbContext _context;
[...]
public GenericRepository(DbContext context)
{
_context = context;
context.Configuration.AutoDetectChangesEnabled = true;
_dbSet = _context.Set<TEntity>();
}
[...]
public void SaveChanges()
{
_context.SaveChanges();
}
[...]
public void Add(TEntity entity)
{
if (entity == null)
{
throw new ArgumentNullException("entity");
}

_dbSet.Add(entity);
}
[...]
public virtual void Update(TEntity entity)
{
_context.Entry(entity).State = EntityState.Modified;
}

在我的 Controller 中,有这段代码:

    [HttpPost]
public ActionResult Edit(Project project)
{
if (ModelState.IsValid)
{
if (project.Id == 0)
{
ProjectRepository.Add(project);
}
else
{
ProjectRepository.Update(project);
}

ProjectRepository.SaveChanges();
[...]

选择和插入工作正常,但更新失败:我收到 InvalidOperationException(德语错误消息的英文翻译为“对象状态管理器中已存在具有相同键的对象。对象状态管理器无法跟踪多个对象使用相同的 key 。”)。

我不明白,因为我是我开发机器上的唯一用户,我没有在其他地方修改记录。

知道我在这里做错了什么吗?

最佳答案

看看这些答案:

基本上你需要这样做:

 var entity = _context.Projects.Find(project.ProjectId);
_context.Entry(entity).CurrentValues.SetValues(project);

希望这对您有所帮助。

关于c# - 使用通用存储库更新实体失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11647957/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com