我遇到了Entity Framework和Code First的问题。 我有一个具有Timestamp属性的实体,我向数据库添加一条新记录,调用SaveChanges,一切正常。 当我尝试删除刚刚添加的记录时,我收到以下消息:
存储更新,插入或删除语句会影响意外 行数(0)。自那以后,实体可能已被修改或删除 实体已加载。刷新ObjectStateManager条目。
在我看来,EF并不知道这条新记录存在于数据库中,尽管它存在于此。 有时,即使我尝试更新不同的记录,我也会收到相同的消息,但如果我尝试删除其他记录,则可以使用。
有谁知道为什么会这样?
提前致谢, 迭
修改 我汇编了一些代码,以便更容易理解我的问题:
我有两个简单的实体:
public class Entidade1
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int ID { get; set; }
public string Descricao { get; set; }
[Timestamp]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public byte[] RecTS { get; set; }
}
public class Entidade2
{
[Key]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public int ID { get; set; }
public string Descricao { get; set; }
[Timestamp]
[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
public byte[] RecTS { get; set; }
public virtual Entidade1 Entidade1 { get; set; }
}
背景:
public class DB : DbContext
{
public DB() : base("DB")
{
this.Configuration.AutoDetectChangesEnabled = true;
this.Configuration.LazyLoadingEnabled = true;
this.Configuration.ProxyCreationEnabled = true;
}
public DbSet<Entidade1> Entidade1 { get; set; }
public DbSet<Entidade2> Entidade2 { get; set; }
}
代码:
var item = new Entidade1();
item.Descricao = "teste";
var db = new DB();
db.Set(typeof(Entidade1)).Add(item);
db.SaveChanges();
var item2 = new Entidade2();
item2.Descricao = "teste 2";
item2.Entidade1 = item;
db.Set(typeof (Entidade2)).Add(item2);
db.SaveChanges();
var q = (from c in db.Entidade1
where c.Descricao == "teste"
select c).FirstOrDefault();
db.Set(typeof(Entidade1)).Remove(q);
db.SaveChanges();
var q2 = (from c in db.Entidade2
where c.Descricao == "teste 2"
select c).FirstOrDefault();
db.Set(typeof (Entidade2)).Remove(q2);
db.SaveChanges(); // Here I got the error
答案 0 :(得分:4)
我发现问题是Entity Framework 4.0中的已知错误,并且自2010年以来它已经出现,并将在下一个版本中得到解决(希望在4.5中)。 当我更新具有相关对象的对象时,EF会尝试更新所有关系,并且由于parentes中没有任何更改,它会给我“0行”消息。
希望它有所帮助。
答案 1 :(得分:1)
我建议,使用Context的本地范围:
Using(var x = new MyObjectContext){ // //.... x.SaveChanges(); }