开发者

Entity framework code first creates "discriminator" column

开发者 https://www.devze.com 2023-04-04 04:10 出处:网络
I am using EF CF approach for a website with MySQL. For some reason EF creates a column in my Post tabl开发者_如何学编程e called \"Discriminator\" and contains the VARCHAR \"Post\".

I am using EF CF approach for a website with MySQL. For some reason EF creates a column in my Post tabl开发者_如何学编程e called "Discriminator" and contains the VARCHAR "Post".

Why is this column created? Can I do something to avoid it being created? Are there any advantages of having this column?


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).


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 
{
}


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>();
}
0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号