簡體   English   中英

為EF6中的所有屬性創建自定義屬性映射

[英]Create custom property mapping for all properties in EF6

模型:

實體類,因為ID在所有實體之間共享

public abstract class Entity
{
    public int Id { get; set; }
}

還有Student類,它繼承了Entity類

public class Student : Entity
{
    public string LastName { get; set; }

    public string Forenames { get; set; }

    public DateTime EnrolmentDate { get; set; }

    public virtual ICollection<Enrolment> Enrolments { get; set; }
}

表格列的命名約定為STUDENT_ID,LAST_NAME,FORENAMES等。所有表格的ID列均為[NAME] _ID

如何為所有實體類中的所有屬性創建自定義映射? 此處引用的代碼不起作用,因為.Entities()方法不再存在。

覆蓋上下文類的OnModelCreating方法,然后可以為每個實體的ID列設置自定義名稱,如下所示:

protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
    modelBuilder.Entity<Student>().Property(x => x.Id).HasColumnName("STUDENT_ID");
    modelBuilder.Entity<Teacher>().Property(x => x.Id).HasColumnName("TEACHER_ID");
}

您可以使用column屬性具有自定義列名映射:

public class Student
{
  [Column("STUDENT_ID")]
  public int Id { get; set; }

  //...
}

我無法將兩個答案都標記為正確(它們都是正確的),但是我試圖達到的目的是將所有列名自動設置為從ColumnName映射到COLUMN_NAME,而不必手動為每個屬性指定列名。

我從“ 循環遍歷實體列”映射中找到答案, 可以轉換列名 ,該列名適用於除ID列之外的所有列,因此我只是使用Yacoub Massad建議的代碼手動設置了它們。

所以:

// Make all properties UPPER_CASE
modelBuilder.Properties()
            .Configure(x => x.HasColumnName(Regex.Replace(x.ClrPropertyInfo.Name, "(?<=.)(?=[A-Z])", "_").ToUpper()));

// Set the ID columns to ENTITY_ID
modelBuilder.Entity<Course>()
    .ToTable("COURSE")
    .Property(x => x.Id)
    .HasColumnName("STUDENT_ID");

如果我沒有那么多的表和列,則為每個屬性設置[Column("ENTITY_ID")]屬性就可以了,但是隨着數據庫的增長以及添加的實體類越來越多,它可能會很重復並且可以易碎,因為它是手動命名的。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM