EF4 Code only mapping inheritance

前端 未结 1 1379
无人共我
无人共我 2021-02-11 04:33

I\'ve got the following model and I want ShiftRequest and MissionRequest to have a single table in the DB.

    public class RequestBase         


        
1条回答
  •  梦毁少年i
    2021-02-11 04:50

    Check the section about TPH in this article. If Mission and Column are complex types you will also find there how to map them. Generally you have to use MapHiearchy and Case methods instead of MapSingleType.

    Edit:

    Here is the example:

    using System;
    using System.Collections.Generic;
    using System.Data.Entity;
    using System.Data.Entity.ModelConfiguration;
    
    
    namespace EFTest
    {
        public class RequestBase
        {
            public int Id { get; set; }
            public DateTime? RequestedDate { get; set; }
            public int UserId { get; set; }
        }
    
        public class Mission
        {
            public int Id { get; set; }
            public string Name { get; set; }
    
            public virtual ICollection MissionRequests { get; set; }
        }
    
        public class Column
        {
            public string Name { get; set; }
        }
    
        public class MissionRequest : RequestBase
        {
            public virtual Mission Mission { get; set; }
        }
    
        public class ShiftRequest : RequestBase
        {
            public Column Column { get; set; }
        }
    
        public class TestContext : DbContext
        {
            public DbSet Requests { get; set; }
            public DbSet Missions { get; set; }
    
            protected override void OnModelCreating(ModelBuilder modelBuilder)
            {
                modelBuilder.ContainerName = "EFTest";
                modelBuilder.IncludeMetadataInDatabase = false;
    
                // Example of complex type mapping. First you have to define 
                // complex type. Than you can access type properties in  
                // MapHiearchy.
                var columnType = modelBuilder.ComplexType();
                columnType.Property(c => c.Name).HasMaxLength(50);
    
                modelBuilder.Entity()
                    .Property(m => m.Id)
                    .IsIdentity();
    
                modelBuilder.Entity()
                    .HasKey(m => m.Id)
                    .MapSingleType(m => new { m.Id, m.Name })
                    .ToTable("dbo.Missions");
    
                modelBuilder.Entity()
                    .Property(r => r.Id)
                    .IsIdentity();
    
                // You map multiple entities to single table. You have to  
                // add some discriminator to differ entity type in the table. 
                modelBuilder.Entity()
                    .HasKey(r => r.Id)
                    .MapHierarchy()
                    .Case(r => new { r.Id, r.RequestedDate, r.UserId, Discriminator = 0 })
                    .Case(m => new { MissionId = m.Mission.Id, Discriminator = 1 })
                    .Case(s => new { ColumnName = s.Column.Name, Discriminator = 2 })
                    .ToTable("dbo.Requests");
            }
        }
    }
    

    Edit 2:

    I updated example. Now Mission is entity instead of complex type.

    0 讨论(0)
提交回复
热议问题