微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – 无法将值NULL插入“Discriminator”列,表’… AspNetUsers’;列不允许空值. INSERT失败

实体框架6,MVC5,ASP Identity 2.0.

我是Entity框架和ASP Identity的新手.
我已按照以下说明使用Code First方法创建数据库http://dotnetcodr.com/2014/07/10/introduction-to-entityframework-6-part-1-the-basics-of-code-first/
并将它们应用于我自己的项目.

创建表,一切都很好.但是当我尝试注册一个新用户时,会抛出异常:“Entity Framework 6,ASP Identity.无法将值NULL插入列’discriminator’,表’… AspNetUsers’;列不允许空值.INSERT失败“.
由AccountController中的CreateAsync方法触发

第153行:{
第154行:var user = new ApplicationUser {UserName = model.Email,Email = model.Email};
第155行:var result = await UserManager.CreateAsync(user,model.Password);
第156行:if(result.Succeeded)
第157行:{

我甚至不确定我应该在这里粘贴哪部分代码.

这是我的DbContext:

public class BulkMailerContext : IdentityDbContext<ApplicationUser>
{
    public BulkMailerContext()
        : base("BulkMailerContext",throwIfV1Schema: false)
    {
    }
    public DbSet<Email> Emails { get; set; }
    public DbSet<SubscriptionList> SubscriptionLists { get; set; }
    public DbSet<Recipient> Recipients { get; set; }
}

这是认的身份上下文:

public class ApplicationDbContext : IdentityDbContext<ApplicationUser>
{
    public ApplicationDbContext()
        : base("BulkMailerContext",throwIfV1Schema: false)
    {
    }
    public static ApplicationDbContext Create()
    {
        return new ApplicationDbContext();
    }
}

我没有找到有关此异常的更多信息.

这个帖子
http://forums.asp.net/t/1974183.aspx?Cannot+insert+the+value+NULL+into+column+Discriminator
建议项目有一个继承自User的类.我没有那样的东西.

这个帖子
https://connect.microsoft.com/VisualStudio/feedback/details/800655/calling-new-user-with-4-5-1-does-not-pass-column-discriminator-required-in-aspnetusers-tables
关于Web API项目,微软团队说这是一个bug,他们会修复它,就我所知

这个
Cannot insert the value NULL into column ‘Discriminator’ AspNetUsers Table
不提供任何解决方

这个
Web API 2 cannot register user
表明在Identity 2.0中已经修复了,但我目前拥有Identity 2.0

我有自动迁移 – 关闭,如果重要的话.但是我已经使用update-database命令从PM控制台手动更新了db.

欢迎提出任何建议.

解决方法

我运行了“add-migration -ConfigurationTypeName … ApplicationContextMigrations.Configuration”InitialCreate“-force”

然后,从数据库删除所有Identity表.

然后运行“update-database … ApplicationContextMigrations.Configuration”

并且discriminator列消失了.当我运行应用程序时,用户已成功注册.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐