如何在 EF4.3 代码优先中映射到复杂类型或从复杂类型映射

本文关键字:映射 复杂 类型 EF4 代码 | 更新日期: 2023-09-27 18:36:17

我有一个这样的实体类型:

public class Invoice{
    public int Id { get; set; }
    public InvoiceNumberSequence Sequence { get; set; }
    public decimal Amount { get; set; }
}

InvoiceNumberSequence如下所示:

public class InvoiceNumberSequence { 
    public string Prefix { get; set; }
    public int Number { get; set; }
    public string GetSequence() {
        return Prefix + Number;
    }
}
我的

问题是我有一个无法更改的现有数据库,并且我正在尝试将表/列映射到我的域模型。表格的外观如下:

[SYSTEMINVOICES]
INVOICE_ID int
INV_TOTAL decimal
INVOICE_SEQ varchar(255)

我有这样的DbContext

public MyDatabaseContext : DbContext {
    public DbSet<Invoice> Invoices { get; set; }
    protected override void OnModelCreating(DbModelBuilder modelBuilder) {
        modelBuilder.Entity<PredictedHeat>().ToTable("SYSTEMINVOICES");
        modelBuilder.Entity<Invoice>().HasKey(p => p.Id);
        modelBuilder.Entity<Invoice>().Property(p => p.Id).HasColumnName("INVOICE_ID");
        modelBuilder.Entity<Invoice>().Property(p => p.Amount).HasColumnName("INV_TOTAL");        
        //need something here to map my invoice sequence to my database table
    }
}

我需要将发票编号序列映射两个方向...1) 从数据库字段到 InvoiceNumberSequence 类,以及 2) 从 InvoiceNumberSequence.GetSequence() 方法到数据库字段。

我该怎么做?

如何在 EF4.3 代码优先中映射到复杂类型或从复杂类型映射

因此,

与其使用GetSequence属性:

public class InvoiceNumberSequence { 
    public string Prefix { get; set; }
    public int Number { get; set; }
    public string Sequence {
        get { retrun Prefix + Number; }
        set { // Add your parsing logic }
    }
}

并在映射中添加:

modelBuilder.ComplexType<InvoiceNumberSequence>()
            .Property(p => p.Sequence)
            .HasColumnName("INVOICE_SEQ");
modelBuilder.ComplexType<InvoiceNumberSequence>()
            .Ignore(p => p.Prefix);
modelBuilder.ComplexType<InvoiceNumberSequence>()
            .Ignore(p => p.Number);