gag*_*gro 1 c# sql-server entity-framework-core asp.net-core
我正在以代码优先的方式使用ASP.NET Core和EF Core。数据库是SQL Server。是否可以Id从0开始递增主键?
使用 EF Core 3.x,您可以使用UseIdentityColumn:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
// ...
modelBuilder.Entity<Blog>()
.Property(x => x.Id)
.UseIdentityColumn(seed: 0, increment: 1);
}
Run Code Online (Sandbox Code Playgroud)
是否可以从0开始递增ID主键?
是。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; }
}
Run Code Online (Sandbox Code Playgroud)
https://docs.microsoft.com/zh-cn/ef/core/modeling/relational/sequences
| 归档时间: |
|
| 查看次数: |
1828 次 |
| 最近记录: |