Автоматическое увеличение PK начиная с нуля - EF Core code-first - PullRequest
0 голосов
/ 25 августа 2018

Я использую ASP.NET Core и EF Core с подходом, основанным на коде.База данных является SQL Server.Можно ли увеличить Id первичный ключ, начиная с 0?

Ответы [ 2 ]

0 голосов
/ 25 августа 2018

Возможно ли увеличить первичный ключ Id, начиная с 0?

Да.EF Core поддерживает последовательности , которые можно запускать где угодно.

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

0 голосов
/ 25 августа 2018

Если вы создаете таблицу с использованием T-SQL Script?

Вы можете создать столбец IDENTITY (свойство) (Transact-SQL) следующим образом:

Синтаксис:

IDENTITY [ (seed , increment ) ]

SQL:

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

Свойство IDENTITY будет автоматически увеличивать столбец с номера 1. (Обратите внимание, что тип данных столбца должен быть целым числом.)Если вы хотите добавить это в существующий столбец, используйте команду ALTER TABLE.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...