ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

CodeGo.net>如何从Asp.Net身份表删除描述符列

2019-11-20 08:08:39  阅读:227  来源: 互联网

标签:asp-net-identity sql c asp-net-mvc entity-framework


我重命名了标准身份表:

    public class User : IdentityUser
    {
        //...
        public string Name { get; set; }
        public string Surname { get; set; }
        public DateTime? RegisteredDate { get; set; }
        public DateTime? LastLoginDate { get; set; }
        //...
    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
        base.OnModelCreating(modelBuilder);
        modelBuilder.Entity<IdentityUser>().ToTable("Users");
        modelBuilder.Entity<User>().ToTable("Users");
        modelBuilder.Entity<IdentityRole>().ToTable("Roles");
        modelBuilder.Entity<Role>().ToTable("Roles");
        modelBuilder.Entity<IdentityUserRole>().ToTable("UserRoles");
        modelBuilder.Entity<IdentityUserLogin>().ToTable("UserLogins");
        modelBuilder.Entity<IdentityUserClaim>().ToTable("UserClaims");
    }

并得到了:

我需要在modelBuilder中删除该列吗?

解决方法:

“按表分层结构”继承方案中使用并要求使用“鉴别符”列.

Code First必须添加一个特殊列以区分持久类.这不是对象模型中持久类的属性; EF Code First在内部使用它.默认情况下,列名称为Discriminator,其类型为字符串.这些值默认为永久类名-在这种情况下为User.
More info

更新资料

如果您不希望使用该列,则可以通过添加DbSet< User>来使User的模型不是IdentityUser的一部分.根据您的情况:

modelBuilder.Entity<User>().ToTable("Users");

标签:asp-net-identity,sql,c,asp-net-mvc,entity-framework
来源: https://codeday.me/bug/20191120/2042523.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有