我在ASP.NET实体框架有一个问题。我想获得Id值每当我添加一个对象到数据库。我该怎么做呢?

根据实体框架,解决方案是:

using (var context = new EntityContext())
{
    var customer = new Customer()
    {
        Name = "John"
    };

    context.Customers.Add(customer);
    context.SaveChanges();
        
    int id = customer.CustomerID;
}

这不会得到数据库表的标识,但得到实体的指定ID,如果我们从表中删除一条记录,种子标识将与实体ID不匹配。


当前回答

您必须将StoreGeneratedPattern的属性设置为identity,然后尝试自己的代码。

或者你也可以用这个。

using (var context = new MyContext())
{
  context.MyEntities.AddObject(myNewObject);
  context.SaveChanges();

  int id = myNewObject.Id; // Your Identity column ID
}

其他回答

您只能在保存后获取ID,相反,您可以在保存前创建一个新的Guid并分配。

Repository.addorupdate(entity, entity.id);
Repository.savechanges();
Var id = entity.id;

这是可行的。

您保存的对象在将更改传播到数据库后应该具有正确的Id。

您需要在保存更改后重新加载实体。因为它已被数据库触发器更改,EF无法跟踪。所以我们需要从数据库中重新加载实体,

db.Entry(MyNewObject).GetDatabaseValues();

然后

int id = myNewObject.Id;

看看@jayantha在以下问题中的回答:

当使用defaultValue时,我如何在实体框架中获得插入实体的Id ?

看看下面这个问题@christian的答案可能也会有帮助:

实体框架刷新上下文?

这很简单。如果您使用DB生成的id(如MS SQL中的IDENTITY),您只需要将实体添加到ObjectSet和相关ObjectContext上的SaveChanges。Id将自动为您填写:

using (var context = new MyContext())
{
  context.MyEntities.Add(myNewObject);
  context.SaveChanges();

  int id = myNewObject.Id; // Yes it's here
}

当使用自动生成的id时,实体框架默认在每个INSERT后面使用SELECT SCOPE_IDENTITY()。