- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在构建一个通用存储库,所有其他方法都可以使用,但更新方法除外。这是代码:
public void Update(T1 obj)
{
T2 item = Mapper.Map<T1, T2>(obj);
//db.Entry(item).State = EntityState.Modified;
//db.Set<T2>().Attach(item);
db.Entry<T2>(item).State = EntityState.Modified;
db.SaveChanges();
}
我正在使用 AutoMapper 将我的业务模型映射到我的实体模型。在我的 Controller 中,我有以下内容:
userModel = userIDService.SelectByID(id);
userModel.Active = false;
userIDService.Update(userModel);
该模型运行良好,并且 Active 值为 False。然而它给了我以下错误:
Attaching an entity of type 'Data.UserIdentification' failed because
another entity of the same type already has the same primary key value.
This can happen when using the 'Attach' method or setting the state of
an entity to 'Unchanged' or 'Modified' if any entities in the graph
have conflicting key values. This may be because some entities are new
and have not yet received database-generated key values. In this case
use the 'Add' method or the 'Added' entity state to track the graph and
then set the state of non-new entities to 'Unchanged' or 'Modified' as
appropriate.
我该如何解决这个问题?我尝试了几种方法都没有成功。添加了通用 repo 代码:
public class GenericRepository<T1, T2>:IGenericRepository<T1>
where T1 : class
where T2: class
{
private Data.Entities db = null;
private DbSet<T2> table = null;
public GenericRepository()
{
this.db = new Data.Entities();
table = db.Set<T2>();
}
public GenericRepository(Entities db)
{
this.db = db;
table = db.Set<T2>();
}
public IQueryable<T1> SelectAll()
{
return table.ToList().AsQueryable().Select(x => Mapper.Map<T2, T1>(x));
}
public T1 SelectByID(object id)
{
return Mapper.Map<T2, T1>(table.Find(id));
}
public void Insert(T1 obj)
{
T2 item = Mapper.Map<T1, T2>(obj);
table.Add(item);
}
public void Update(T1 obj)
{
//T2 item = Mapper.Map<T1, T2>(obj);
//table.Attach(item);
//db.Entry<T2>(item).State = EntityState.Modified;
//db.SaveChanges();
T2 item = Mapper.Map<T1, T2>(obj);
db.Set<T2>().Attach(item);
db.Entry<T2>(item).State = EntityState.Modified;
db.SaveChanges();
}
public void Delete(object id)
{
T2 existing = table.Find(id);
table.Remove(existing);
}
public void Save()
{
db.SaveChanges();
}
EDIT2:添加了 UserIdentification 实体
public partial class UserIdentification
{
public System.Guid id { get; set; }
public System.Guid user_id { get; set; }
public int id_type { get; set; }
public System.DateTime expiration_date { get; set; }
public System.DateTime Created { get; set; }
public Nullable<bool> Active { get; set; }
public virtual IdentificationType IdentificationType { get; set; }
public virtual UserInfo UserInfo { get; set; }
}
编辑 3:商业模式
public Guid id { get; set; }
public System.Guid user_id { get; set; }
public int id_type { get; set; }
public System.DateTime expiration_date { get; set; }
public System.DateTime Created { get; set; }
public Nullable<bool> Active { get; set; }
public virtual IdentificationType IdentificationType { get; set; }
最佳答案
如果您对检索和更新操作使用相同的 DbContext
,那么在您更新时,您的上下文已经跟踪了您的实体(具有此主键的实体)。来自 MSDN :
Changing the state of a tracked entity
You can change the state of an entity that is already being tracked by setting the State property on its entry. For example:
var existingBlog = new Blog { BlogId = 1, Name = "ADO.NET Blog" };
using (var context = new BloggingContext())
{
context.Blogs.Attach(existingBlog);
context.Entry(existingBlog).State = EntityState.Unchanged;
// Do some more work...
context.SaveChanges();
}
Note that calling Add or Attach for an entity that is already tracked can also be used to change the entity state. For example, calling Attach for an entity that is currently in the Added state will change its state to Unchanged.
我认为您缺少 Attach
调用(您已注释掉)。请尝试
public void Update(T1 obj)
{
T2 item = Mapper.Map<T1, T2>(obj);
db.Set<T2>().Attach(item);
db.Entry<T2>(item).State = EntityState.Modified;
db.SaveChanges();
}
关于c# - 更新通用存储库中的实体时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31685516/
我使用 AppFuse 创建项目已经有一段时间了。我已经知道有两种方法可以开发 DAO 和 Manager 类: GenericDao/GenericManager 方法 UniversalDao/U
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
在普通的单线程程序中,捕获异常只需要通过try ... catch ... finally ...代码块就可以了。那么,在并发情况下,比如在父线程中启动了子线程,如何在父线程中捕获来自子线程的异常,
假设我有一个这样的界面 interface Example { first_name: string, last_name: string, home_town: string
我已经成为 hg 用户几年了,对此我很高兴! 我必须开始一个我以前从未做过的项目。我们的想法是开发一个具有批处理模式和 GUI 的软件。 因此,批处理模式和 GUI 模式都有共同的源,但每种模式也都包
我可以在Silverlight中使用generic.xaml来设置应用程序中所有TextBlock的样式吗? 我原以为它会起作用,但它没
顶部 map 有 3 个子 map ,每个子 map 都有不同的对象。 像下面的代码,如何将通用添加到 map 顶部? Map top = new ConcurrentHashMap();
我想创建一个hashmap,其中键是接口(interface)A,值是接口(interface)B。然后我想用实现A和B的类来初始化它。是否可以使用java泛型来做到这一点? 也就是说,我想要类似的东
Enum 位于 java.lang.Enum 中,Object 位于 java.lang.Object 中>。那么,为什么 Enum 不是 Object 呢? (我收到一个java.lang.Clas
我有一种方法,check,它有两个 HashMap 作为参数。这些映射的键是 String,值是 String 或 Arraylist。 哪个是更好的解决方案: public static boole
我启动了针对iPhone的应用程序,现在我也想将其应用程序用于iPad。当我开始做iPhone项目时,即使我添加了iPad xib,它也无法正确显示,如何转换我的项目同时适用于iPhone和iPad(
这行代码(代码1)有什么区别 auto l1 = [](auto a) { static int l = 0; std::cout operator() for type const char*) 被
使用 Generic#to,我可以获得 case class 的 HList 表示: import shapeless._ case class F(x: Int, y: String) scala>
我有一个 BiDiMap 类。如何使其通用,不仅接受 String 而且接受 Object 类型的对象作为输入参数,同时保持所有原始函数正常工作。例如,我希望能够使用函数 put() 和 Object
我在编译 foreach 循环时遇到问题。我很确定这是我的泛型处理的问题,因为该错误是对象兼容性问题。我已搜索解决方案,但找不到任何可以解决该问题的内容。 这是定义 Iterable adjList
大约有 6 个 POJO 类(域实体、DTO、DMO)都具有几乎相同的字段。为了从一个对象转换为另一个对象,我传递一个对象并调用它的 getter 将其设置到另一个对象中。 private UserT
有没有什么方法可以创建一个通用的 for 循环,它可以正确地循环遍历数组或对象?我知道我可以编写以下 for 循环,但它也会遍历将添加到数组的其他属性。 for (item in x) { co
我已经有一段时间没有写js了,显然有点生疏了。试图理解以下问题。 getCurrentPosition successCallback 中的警报正确显示纬度,但最后一行警报未定义。为什么我的 clie
请帮助我,我从来没有用 xib 为 iPhone/iPad 制作过通用的 UIViewControllers。如何使用 .m 和 .h 文件以及 _iphone.xib 和 _ipad.xib 创建类
我正在尝试创建一个 createRequest 函数,我可以将其重新用于我的所有网络调用,有些需要发布 JSON 而其他则不需要,所以我正在考虑创建一个采用可选通用对象的函数;理论上是这样的: str
我是一名优秀的程序员,十分优秀!