I am using EF CF approach for a website with MySQL. For some reason EF creates a column in my Post table called \"Discriminator\" and contains the VARCHAR \"Post\".
For completeness, if you want to use the fluent API to stop the inheriting class from being mapped with entity (and therefore stopping the discriminator column being created) you can do the following:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Ignore<InheritingClass>();
}
You can stop the column being created by adding the [NotMapped]
data annotation to the models that are inheriting from your base class. This will tell EF not to add your class to future migrations, removing the discriminator column.
public class BaseClass
{
}
[NotMapped]
public class InheritingClass : BaseClass
{
}
The Discriminator
column is used and required in Table-Per-Hierarchy inheritance scenarios. If you for example have a model like this ...
public abstract class BaseEntity
{
public int Id { get; set; }
//...
}
public class Post : BaseEntity
{
//...
}
public class OtherEntity : BaseEntity
{
//...
}
... and make the BaseEntity
part of the model, for instance by adding a DbSet<BaseEntity>
to your derived context, Entity Framework will map this class hierarchy by default into a single table, but introduce a special column - the Discriminator
- to distinguish between the different types (Post
or OtherEntity
) stored in this table. This column gets populated with the name of the type (again Post
or OtherEntity
).