ICode9

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

c# – 在实体框架4.1中将discriminator列更改为int

2019-05-18 12:55:01  阅读:250  来源: 互联网

标签:c entity-framework-4-1 ef-code-first code-first


这是我的情况,非常简化.

我的课程;

public class ClassBase
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int Id { get; set; }
}

public class ClassMiddle1 : ClassBase
{

}

public class ClassMiddle2 : ClassBase
{
    public Guid Token { get; set; }
}

public class ClassA : ClassMiddle1
{
    public string UserId { get; set; }
    public string Username { get; set; }
}

public class ClassB : ClassMiddle2
{
    public string Username { get; set; }
}

而我的OnModelCreating;

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<ClassBase>()
        .Map(m => {
            m.Properties(p => new { p.Id});
            m.ToTable("TableBase");
        });

    modelBuilder.Entity<ClassMiddle1>()
        .Map<ClassMiddle1>(m =>
        {
            m.Properties(p => new { });
            m.ToTable("TableBase");
        });

    modelBuilder.Entity<ClassMiddle2>()
        .Map<ClassMiddle2>(m =>
        {
            m.Properties(p => new { p.Token });
            m.ToTable("TableBase");
        });

    modelBuilder.Entity<ClassA>()
        .Map<ClassA>(m =>
        {
            m.Properties(p => new
            {
                p.UserId,
                p.Username
            });
            m.ToTable("TableA");

        });

    modelBuilder.Entity<ClassB>()
        .Map<ClassB>(m =>
        {
            m.Properties(p => new
            {
                p.Username
            });
            m.ToTable("TableB");

        }).Property(p => p.Username).HasColumnName("User");

}

这工作正常,但Discriminator列默认为Discriminator,NVARCHAR(128).我读到可以使用下面的内容自己定义此列.

m.Requires("ClassType").HasValue(1);

我把自己的可能性彻底改变了,但所有时间都陷入了死胡同.有人建议怎么做?

我将以另一个问题结束.由于我们的层次结构几乎与上面相同,但是更多的衍生类如C,D,E,F等等……说P.我们发现EF正在进行这个令人难以置信的大数据库查询(~150K).其他人遇到过这种情况?

我希望改变Discriminator至少最小化这个.据我所知,我们有一个非常整洁的类层次结构,但丑陋的查询集.

解决方法:

迟回答实际解决方案是如何进行的.只在这里写下来,因为围绕这个的文档并不那么容易找到.

我的解决方案最终如下…

modelBuilder.Entity<ClassBase>()
        .Map(m => {
            ...
            m.Requires("Discriminator").HasValue(1)
        });

标签:c,entity-framework-4-1,ef-code-first,code-first
来源: https://codeday.me/bug/20190518/1128243.html

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

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

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

ICode9版权所有