0

我将我的应用程序从 .Net Core 1.1、EF Core 1.1、ASP.Net Identity 1.1 迁移到所有版本 2.1。我还将我自己的用户(当前称为Diver)与 IdentityUser 分开,因此我不需要向 ASP.Net Idenentity-EF 提供自定义用户类。

当我现在尝试添加初始迁移时:

dotnet ef migrations add initial -s . -p ../Tauchbolde.Common/

我得到错误:

The entity type 'IdentityUserLogin<int>' requires a primary key to be defined.

我的上下文如下所示:

public class ApplicationDbContext : IdentityDbContext
{
    public ApplicationDbContext(DbContextOptions<ApplicationDbContext> options)
    : base(options)
    { }

    public DbSet<Event> Events { get; set; }
    public DbSet<Participant> Participants { get; set; }
    public DbSet<Comment> Comments { get; set; }
    public DbSet<Diver> Diver { get; set; }
    public DbSet<Notification> Notifications { get; set; }
    public DbSet<Post> Posts { get; set; }
    public DbSet<PostImage> PostImages { get; set; }

    protected override void OnModelCreating(ModelBuilder builder)
    {
        base.OnModelCreating(builder);

        // ApplicationUser
        builder.Entity<Diver>()
            .HasMany(e => e.Notificationses)
            .WithOne(e => e.Recipient)
            .OnDelete(DeleteBehavior.Restrict);
        builder.Entity<Diver>()
            .HasMany(e => e.Comments)
            .WithOne(e => e.Author)
            .OnDelete(DeleteBehavior.Restrict);
        builder.Entity<Diver>()
            .HasMany(e => e.Events)
            .WithOne(e => e.Organisator)
            .OnDelete(DeleteBehavior.Restrict);
        builder.Entity<Diver>()
            .HasMany(e => e.Posts)
            .WithOne(e => e.Author)
            .OnDelete(DeleteBehavior.Restrict);
        builder.Entity<Diver>()
            .HasMany(e => e.Claims)
            .WithOne()
            .HasForeignKey(e => e.UserId)
            .IsRequired()
            .OnDelete(DeleteBehavior.Cascade);
        builder.Entity<Diver>()
            .HasMany(e => e.Logins)
            .WithOne()
            .HasForeignKey(e => e.UserId)
            .IsRequired()
            .OnDelete(DeleteBehavior.Cascade);
        builder.Entity<Diver>()
            .HasMany(e => e.Roles)
            .WithOne()
            .HasForeignKey(e => e.UserId)
            .IsRequired()
            .OnDelete(DeleteBehavior.Cascade);

        // Comment
        builder.Entity<Comment>().HasOne(e => e.Event).WithMany(e => e.Comments).OnDelete(DeleteBehavior.Restrict);

        // Event
        builder.Entity<Event>().HasIndex(p => new { p.StartTime, p.Deleted });
        builder.Entity<Event>().Property(e => e.Deleted).HasDefaultValue(false);
        builder.Entity<Event>().Property(e => e.Canceled).HasDefaultValue(false);

        // Notification
        builder.Entity<Notification>().Property(e => e.AlreadySent).HasDefaultValue(false);
        builder.Entity<Notification>().Property(e => e.CountOfTries).HasDefaultValue(0);

        // Participants
        builder.Entity<Participant>().HasOne(e => e.Event).WithMany(e => e.Participants).OnDelete(DeleteBehavior.Restrict);
        builder.Entity<Participant>().Property(e => e.CountPeople).HasDefaultValue(1);

        // Post
        builder.Entity<Post>().HasIndex(p => new { p.Category, p.PublishDate });

        // PostImage

        // UserInfo
        builder.Entity<Diver>().Property(e => e.NotificationIntervalInHours).HasDefaultValue(1);
    }

完整的源代码可以在GitHub上找到。

我已经尝试了很多东西,比如为 Identity 实体添加忽略语句。没有任何效果,我被卡住了。

有什么想法会出错吗?

4

2 回答 2

0

我不确定,但尝试用这个替换你的第一行:

public class ApplicationDbContext : IdentityDbContext<IdentityUser>
于 2018-09-27T15:44:19.717 回答
0

看起来我的实体与 ASP.Net 身份实体有一些关系。似乎我在从继承的身份用户实体切换时没有清理它们。我还在我的 DBContext 中添加了另外两个构造函数,它们不使用泛型参数,而是使用默认参数。这已经修复了我现在能够使用问题中显示的推荐添加迁移的方式。

于 2018-10-02T05:12:55.437 回答