我在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不匹配。


当前回答

当你使用EF 6。X码优先

    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public Guid Id { get; set; }

并初始化一个数据库表,它会放一个

(newsequentialid())

在表头Default Value或Binding下的表属性中,允许在插入时填充ID。

问题是,如果创建一个表并添加

[DatabaseGenerated(DatabaseGeneratedOption.Identity)]

稍后,未来的更新数据库将不会添加回(newsequentialid())

正确的修复方法是擦除迁移,删除数据库,重新迁移…或者你可以在表设计器中添加(newsequentialid())。

其他回答

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

我正在使用MySQL数据库,我有一个AUTO_INCREMENT字段Id。

我在EF也遇到了同样的问题。

我试过下面的行,但它总是返回0。

      await _dbContext.Order_Master.AddAsync(placeOrderModel.orderMaster);
      await _dbContext.SaveChangesAsync();

      int _orderID = (int)placeOrderModel.orderMaster.Id;

但我意识到我的错误并改正了它。

我正在做的错误:我在orderMaster模型中为Id字段传递0

解决方案起作用了:一旦我从orderMaster模型中删除Id字段,它就开始工作了。

我知道这是个很愚蠢的错误,但如果有人没注意到,就写在这里。

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

有两种策略:

使用数据库生成的ID (int或GUID) 缺点: 您应该执行SaveChanges()来获取刚刚保存的实体的ID。 优点: 可以使用int标识。 仅使用客户端生成的ID - GUID。 优点: 缩小SaveChanges操作。 能够在每次操作中插入新对象的大图形。 缺点: 只允许用于GUID

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

db.Entry(MyNewObject).GetDatabaseValues();

然后

int id = myNewObject.Id;

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

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

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

实体框架刷新上下文?