我正在以代码优先方式使用ASP.NET Core和EF Core。数据库是SQL Server。是否可以从0开始递增Id
主键?
答案 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命令。