从零开始自动递增PK-EF核心代码优先

时间:2018-08-24 22:23:44

标签: c# sql-server asp.net-core entity-framework-core

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

3 个答案:

答案 0 :(得分:4)

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

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

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

答案 1 :(得分:3)

  

是否可以从0开始递增ID主键?

是的。 EF Core支持Sequences,可随时随地启动。

EG:

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://docs.microsoft.com/en-us/ef/core/modeling/relational/sequences

答案 2 :(得分:1)

如果要使用T-SQL脚本创建表?

您可以创建一个IDENTITY (Property) (Transact-SQL)列,如下所示:

语法:

IDENTITY [ (seed , increment ) ]

SQL:

CREATE TABLE (
  ID_column INT NOT NULL IDENTITY(1,1) PRIMARY KEY,
  ...
);

IDENTITY属性将使列从数字1开始自动递增。(请注意,列的数据类型应为整数。)如果要将其添加到现有列,请使用ALTER TABLE命令。