我可以在EF代码中使用非抽象基类的第一个TPH吗?

时间:2016-11-01 23:27:42

标签: xaf ef-code-first-mapping

定义的SQL Server中有一个表
    CREATE TABLE [dbo].[ReportDataV2](
    [ID] [int] IDENTITY(1,1) NOT NULL,
    [DataTypeName] [nvarchar](max) NULL,
    [IsInplaceReport] [bit] NOT NULL,
    [PredefinedReportTypeName] [nvarchar](max) NULL,
    [Content] [varbinary](max) NULL,
    [DisplayName] [nvarchar](max) NULL,
    [ParametersObjectTypeName] [nvarchar](max) NULL,
 CONSTRAINT [PK_dbo.ReportDataV2] PRIMARY KEY CLUSTERED 
(
    [ID] ASC
)WITH (PAD_INDEX  = OFF, STATISTICS_NORECOMPUTE  = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS  = ON, ALLOW_PAGE_LOCKS  = ON) ON [PRIMARY]
) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

恰好是Dev Express XAF报告表。

在我的数据环境中,我有

public DbSet<ReportDataV2> ReportDataV2 { get; set; }

我希望能够将DataTypeName字段视为鉴别器列,而不会干扰ReportDataV2在我的代码中的工作方式。

我尝试了以下操作,但实体框架检测到数据结构已更改,如果生成迁移,我发现它正在尝试重新创建ReportDataV2表。

public class OrderCountReport2Configuration : EntityTypeConfiguration<ReportDataV2>
{
    public OrderCountReportConfiguration()
        : base()
    {
         ToTable("ReportDataV2", "dbo");

         HasKey(tp => tp.ID);

        Map<OrderCountReport>(m => m.Requires("DataTypeName").HasValue("OrderCountReport"));

    }
}

   protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Configurations.Add(new OrderCountReportConfiguration());
        base.OnModelCreating(modelBuilder);
    }
}

1 个答案:

答案 0 :(得分:0)

鉴别器列必须具有大小限制,就像索引列需要大小限制一样