Тип сущности 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserLogin <string>' требует определения ключа

c# asp.net-mvc asp.net-identity entity-framework-core

10282 просмотра

1 ответ

160 Репутация автора

У меня есть приложение ASP.NET5 MVC, использующее EF7. Пока все работает нормально, и я могу добавлять миграции и сохранять данные в базе данных. Теперь после добавления Identity в мой проект уровня данных я получаю эту ошибку при попытке добавить новую миграцию:

Тип сущности 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserLogin' требует определения ключа

Мой контекст получен из IdentityDbContext:

public class ASSWebApiContext : IdentityDbContext<AppUser>

класс AppUser:

using Microsoft.AspNet.Identity.EntityFramework;
using System;

namespace ASS.DomainDataModel.Models
{
    public class AppUser : IdentityUser
    {
        public string AppUserId { get; set; }
        public DateTime FirstFlight { get; set; }
    }
}

project.json

{
  "version": "1.0.0-*",
  "description": "ASS.DomainDataModel Class Library",
  "authors": [ "xxxx" ],
  "tags": [ "" ],
  "projectUrl": "",
  "licenseUrl": "",

  "frameworks": {
    "dnx451": {
      "dependencies": {
      }
    },
    "dnxcore50": {
      "dependencies": {
      }
    }
  },

  "dependencies": {
    "ASS.DomainClasses": "1.0.0-*",
    "Microsoft.Extensions.PlatformAbstractions": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.EnvironmentVariables": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.FileExtensions": "1.0.0-rc1-final",
    "Microsoft.Extensions.Configuration.Json": "1.0.0-rc1-final",
    "EntityFramework.Core": "7.0.0-rc1-final",
    "EntityFramework.Commands": "7.0.0-rc1-final",
    "EntityFramework.Relational": "7.0.0-rc1-final",
    "System.Linq.Expressions": "4.0.11-beta-23516",
    "EntityFramework.MicrosoftSqlServer": "7.0.0-rc1-final",
    "Microsoft.AspNet.Identity.EntityFramework": "3.0.0-rc1-final"
  },

    "commands": {
    "ef": "EntityFramework.Commands"
  }
}

Все, что я сделал здесь, это загрузил соответствующий новый пакет: «Microsoft.AspNet.Identity.EntityFramework»: «3.0.0-rc1-final», добавил класс AppUser - больше ничего. У меня был похожий проект, использующий бета-8 с использованием точно такой же схемы, где он работал без проблем. Есть ли какие-либо существенные изменения между бета-8 и RC-1?

Спасибо!

Ниже приведена часть ASSWebApiContext. Для большинства сущностей, имеющих DbSet, есть modelBuilder.Entity. Так что файл продолжается довольно долго ...

using Microsoft.Data.Entity;
using ASS.DomainClasses.Entities;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.PlatformAbstractions;
using System.Linq;
using ASS.DomainClasses.Interfaces;
using System;
using Microsoft.AspNet.Identity.EntityFramework;

namespace ASS.DomainDataModel.Models
{
    public class ASSWebApiContext : IdentityDbContext<AppUser>
    {
        public IConfigurationBuilder Config { get; set; }
        public IConfigurationRoot _Configuration { get; private set; }

        public ASSWebApiContext(IApplicationEnvironment appEnv)
        {
            Database.EnsureCreated();

            Config = new ConfigurationBuilder()
                .SetBasePath(appEnv.ApplicationBasePath)
                .AddJsonFile("config.json");

            _Configuration = Config.Build();

        }

        public DbSet<Address> Addresses { get; set; }
        public DbSet<AddressType> AddressTypes { get; set; }
        public DbSet<Aircraft> Aircrafts { get; set; }
        public DbSet<AircraftModel> AircraftModels { get; set; }
        public DbSet<AircraftOwner> AircraftOwners { get; set; }
        public DbSet<AircraftOwnerType> AircraftOwnerTypes { get; set; }
        public DbSet<Country> Countries { get; set; }
        public DbSet<GPEncodingType> GPEncodingTypes { get; set; }
        public DbSet<LocationPoint> LocationPoints { get; set; }
        public DbSet<Manufacturer> Manufacturer { get; set; }
        public DbSet<Pilot> Pilots { get; set; }
        public DbSet<ServiceProvider> ServiceProviders { get; set; }
        public DbSet<State> States { get; set; }
        public DbSet<Trip> Trips { get; set; }
        public DbSet<Stop> Stops { get; set; }
        public DbSet<Track> Tracks { get; set; }


        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {


            modelBuilder.Entity<AddressType>(
                e =>
                {
                    e.Property(n => n.AddressTypeId).IsRequired().UseSqlServerIdentityColumn();
                    e.Property(n => n.Name).IsRequired().HasMaxLength(15);
                    e.Ignore(n => n.IsDirty);
                });

            modelBuilder.Entity<Address>(
                e =>
                {
                    e.Property(n => n.AddressId).IsRequired().UseSqlServerIdentityColumn();
                    e.Property(n => n.AddressTypeId).IsRequired();
                    e.Property(i => i.CountryId).HasMaxLength(2);
                    e.Property(i => i.AddrLine1).HasMaxLength(256);
                    e.Property(i => i.AddrLine2).HasMaxLength(256);
                    e.Property(i => i.AddrLine3).HasMaxLength(256);
                    e.Property(i => i.Postcode).HasMaxLength(50);
                    e.Ignore(n => n.IsDirty);
                });
...
Автор: Olaf D. Источник Размещён: 30.11.2015 01:45

Ответы (1)


37 плюса

13779 Репутация автора

Решение

В основном ключи таблиц идентификации отображаются в OnModelCreatingметоде, IdentityDbContextи если этот метод не вызывается, вы в конечном итоге получите полученную ошибку. Этот метод не вызывается, если вы наследуете IdentityDbContextи предоставляете свое собственное определение, OnModelCreatingкак в коде. С этой настройкой вы должны явно вызвать OnModelCreatingметод IdentityDbContextиспользования base.OnModelCreatingоператора. Этот ответ также обсуждает вариант, который я разместил здесь

Автор: Muhammad Adeel Zahid Размещён: 01.12.2015 05:43
Вопросы из категории :
32x32