Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

What is a Discriminator column in ASP.NET Migrations?

Tags:

I needed to add an extra field to Role identity table in ASP.NET MVC 5.

I use migrations.

I have added an extension to role like:

public class ApplicationRole : IdentityRole {     public ApplicationRole() : base() { }      public ApplicationRole(string name)         : base(name)     {     }      public virtual Project Project { get; set; } }    

My migration class, I'm getting is:

public partial class ProjectToIdentity : DbMigration {     public override void Up()     {         CreateTable(             "dbo.Projects",             c => new                 {                     ID = c.Int(nullable: false, identity: true),                     ProjectName = c.String(maxLength: 100),                 })             .PrimaryKey(t => t.ID);          AddColumn("dbo.AspNetRoles", "Discriminator", c => c.String(nullable: false, maxLength: 128));         AddColumn("dbo.AspNetRoles", "Project_ID", c => c.Int());         CreateIndex("dbo.AspNetRoles", "Project_ID");         AddForeignKey("dbo.AspNetRoles", "Project_ID", "dbo.Projects", "ID");     }      public override void Down()     {         DropForeignKey("dbo.AspNetRoles", "Project_ID", "dbo.Projects");         DropIndex("dbo.AspNetRoles", new[] { "Project_ID" });         DropColumn("dbo.AspNetRoles", "Project_ID");         DropColumn("dbo.AspNetRoles", "Discriminator");         DropTable("dbo.Projects");     } } 

The question is - what is a Discriminator column? I have no such column in my model. Why does migration tool adds this field and what aim does it have?

like image 417
Oleksii Avatar asked Jan 20 '15 20:01

Oleksii


1 Answers

Well, a quick answer to understand, or, at least, make it more clear.

As Jasen told, you can read about Table per Hierarchy (TPH) at http://weblogs.asp.net/manavi/inheritance-mapping-strategies-with-entity-framework-code-first-ctp5-part-1-table-per-hierarchy-tph or any other links. But, to tell the truth, it's not so easy to understand from the first time.

Here is a quick answer:

  1. Try to create a new role, using ApplicationRole (the class, that was posted in question), inherited from IdentityRole
  2. After you create a new role, take a look on Discrimination fields.

As you'll see - the new record contains "ApplicationRole" in the Discrimination column. So to say - that column contains the name of the new class, that inherits IdentityRole. So, there probably can be more classes, which will be inheriting IdentityRole, but for each record the Identity system will store the value - using which class the record was created.

enter image description here

As shown, ApplicationRole Discriminator appeared only for the record, created by the class, called ApplicationRole that inherits IdentityRole.

like image 110
Oleksii Avatar answered Oct 01 '22 03:10

Oleksii