从零开始自动递增主键 - EF Core Code-First

5

我正在使用ASP.NET Core和EF Core进行代码优先的开发。数据库是SQL Server。是否可以从0开始递增Id主键?


为什么你想从0开始? - Shyju
@Shyju 我在特定表中只有3行,而且在UI上它们需要分别具有ID 0、1、2。我知道我可以创建另一个ID字段并为了UI而硬编码它们,但我很好奇是否可以不使用额外的字段。 - gagro
发布你的代码以及期望的结果,因为对于你的问题来说,简单的答案是“是”。 - Pm Duda
我建议在这个表上完全不使用 identity。只需使用普通的 Id int primary key,然后用你明确的值填充它。 - Roger Wolf
3个回答

10

使用 EF Core 3.x,您可以使用 UseIdentityColumn

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    // ...

    modelBuilder.Entity<Blog>()
        .Property(x => x.Id)
        .UseIdentityColumn(seed: 0, increment: 1);
}


8

可以将主键Id从0开始递增吗?

是的。EF Core支持Sequences序列,您可以从任何位置开始。

例如:

class MyContext : DbContext
{
    public DbSet<Order> Orders { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.HasSequence<int>("Order_seq", schema: "dbo")
            .StartsAt(0)
            .IncrementsBy(1);

        modelBuilder.Entity<Order>()
            .Property(o => o.OrderNo)
            .HasDefaultValueSql("NEXT VALUE FOR dbo.Order_seq");
    }
}

public class Order
{
    public int OrderId { get; set; }
    public int OrderNo { get; set; }
    public string Url { get; set; }
}

https://learn.microsoft.com/en-us/ef/core/modeling/relational/sequences


如果我没错的话,根据这个,我的Context类中所有的DbSet都会以0开始?如果我只想让一个DbSet(表)从0开始怎么办? - gagro
为每个实体创建不同的序列对象。 - David Browne - Microsoft

1
如果您正在使用T-SQL脚本创建表格?
您可以按照以下方式创建一个IDENTITY (Property) (Transact-SQL)列: 语法:
IDENTITY [ (seed , increment ) ]

SQL:

CREATE TABLE (
  ID_column INT NOT NULL IDENTITY(1,1) PRIMARY KEY,
  ...
);
< p > IDENTITY 属性将自动递增列号从1开始。(请注意,该列的数据类型应为整数。) 如果您想将其添加到现有列中,请使用 ALTER TABLE 命令。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接