c# – Entity Framework,我以前添加过此条目吗?
发布时间:2020-12-15 20:59:28 所属栏目:百科 来源:网络整理
导读:我有一个简单的实体. public partial class Thing{ public Thing() {} public int Id { get; set; } public string Name { get; set; } } 我将数千个新条目插入到localDB数据库中,但只会有一些特殊的东西. 如果我在每次插入后保存更改,那么它将运行得非常慢,
我有一个简单的实体.
public partial class Thing { public Thing() {} public int Id { get; set; } public string Name { get; set; } } 我将数千个新条目插入到localDB数据库中,但只会有一些特殊的东西. Thing newThing = new Thing(); newThing.Name = "MyName"; context.Things.Add(d); //returns null Thing myFirstThing = context.Things.FirstOrDefault(c => c.Name == newThing.Name); //returns false if (context.Detectors.Any(c => c.Name == newThing.Name)) { //do some stuff} 解决方法
我认为您可以使用DbContext上的ChangeTracker执行此操作,但是,它可能会很慢.
//(warning: free-handing this): myContext.ChangeTracker.Entries<theEntityType>().Any(e => e.State == EntityState.Added && e.Entity.TheField == yourString); 我认为(或者关闭的东西会起作用,但是它可能变得很慢,因为你在每次调用时扫描一个集合.(每次添加后它会变慢一点 – 一个拥有1000个成员的集合会烧掉很多蜱) 相反,您可以将实体添加到Dictionary< yourString,theEntity>当你添加它们.字典中基于键的查找是O(1),因此即使字典中有一百万个条目,查找速度也非常快.保存实体时清除字典以使内存更轻松. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |