Вставьте значение в столбец идентификации в Core 2.2 - PullRequest
0 голосов
/ 25 февраля 2019

Попытка заполнить базу данных на сервере MSSQL.Столбец «Id» установлен на идентичность.Я не понимаю, почему EF нужны данные для 'Id:

public class Location
{
    public int? Id { get; set; }

    public string Name { get; set; }

    public IList<Office> Offices { get; set; }

}

... свободно API:

modelBuilder.Entity<Location>()
     .HasKey(k => k.Id);

modelBuilder.Entity<Location>()
     .Property(p => p.Id)
     .UseSqlServerIdentityColumn()
     .ValueGeneratedOnAdd();

modelBuilder.Entity<Location>()
     .HasData(
            new Location() { Name = "Sydney" },
            new Location() { Name = "Melbourne" },
            new Location() { Name = "Brisbane" }
    );

... насколько я понимаю, "Id" недолжны быть предоставлены, если они генерируются сервером при вставке.Почему я получаю сообщения об отсутствии предоставления идентификатора ...

1 Ответ

0 голосов
/ 25 февраля 2019

Я думаю, что ошибка здесь

public int? Id { get; set; }

Идентификатор не должен быть обнуляемым.

Обновление: Я имею в виду, что вы должны написать:

public int Id { get; set; }

Знак вопроса делает ваше свойство обнуляемым, но так как оно является первичным ключом, оно не может быть нулевым.

Я сделал небольшой пример здесь:

using System.Collections.Generic;

namespace ConsoleApp2.Models
{
    public class Location
    {
        public int Id { get; set; }

        public string Name { get; set; }

        public IList<Office> Offices { get; set; }
    }
}

СвободноApi

      migrationBuilder.CreateTable(
                name: "Locations",
                columns: table => new
                {
                    Id = table.Column<int>(nullable: false)
                        .Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
                    Name = table.Column<string>(nullable: true)
                },
                constraints: table =>
                {
                    table.PrimaryKey("PK_Locations", x => x.Id);
                });

Я могу добавить новое местоположение без проблем.

using ConsoleApp2.Models;
using System.Collections.Generic;

namespace ConsoleApp2
{
    class Program
    {
        static void Main(string[] args)
        {
            MyDbContext _c = new MyDbContext();

            List<Office> list = new List<Office>()
            {
                  new Office()
                {
                    OfficeName = "Reception"
                }
            };


            Location l = new Location()
            {
                Name = "New York",
                Offices = list
            };

            _c.Locations.Add(l);
            _c.SaveChanges();
        }
    }
}

Я использую .net core 2.1 с EFcore 2.2.2.

Надеюсь, это поможет.

...