【问题标题】:Mapping to already existing database table映射到已经存在的数据库表
【发布时间】:2012-02-09 13:46:56
【问题描述】:

我正在使用Entity Framework 4.1 code first 连接到已经存在的数据库。我首先使用的表称为Bank。我还有一个Bank class 作为我的域模型。这就是我映射班级和表格的方式:

public class HbfContext : DbContext
{
     public DbSet<Bank> Banks { get; set; }

     protected override void OnModelCreating(DbModelBuilder modelBuilder)
     {
          modelBuilder.Entity<Bank>().ToTable("Bank");
     }
}

我的银行表:

BankID INT
BankName VARCHAR(50)

我的银行类如下所示:

public class Bank
{
     public int Id { get; set; }
     public string Name { get; set; }
     public bool IsActive { get; set; }
}

我想退回所有银行时遇到问题。返回的 SQL 语句:

return db.Banks
     .OrderBy(x => x.Name);

是:

SELECT
     [Extent1].[Id] AS [Id],
     [Extent1].[Name] AS [Name],
     [Extent1].[IsActive] AS [IsActive]
FROM
     [dbo].[Bank] AS [Extent1]
ORDER BY
     [Extent1].[Name] ASC

这不起作用,因为我的表没有 Id、Name 和 IsActive 列。我将如何解决这个问题,EF 会自动将 BankId 映射到 Id 并将 BankName 映射到 Name 吗?

【问题讨论】:

    标签: c# entity-framework ef-code-first ef-fluent-api


    【解决方案1】:

    您需要指示 EF 忽略 IsActive 属性并映射其他属性。如果您不喜欢数据注释,您可以使用 fluent API 进行此操作:

    modelBuilder.Entity<Bank>().Ignore(b => b.IsActive);
    modelBuilder.Entity<Bank>().Property(b => b.Id).HasColumnName("BankID");
    modelBuilder.Entity<Bank>().Property(b => b.Name).HasColumnName("BankName");
    

    【讨论】:

    • 在我的表结构中没有 Id 和 Name 列。因此,与其更改域模型的属性,不如通过 fluent API 将列名映射到属性?
    • 我错过了这部分。如果您的类声明与您的表不同,则必须映射所有差异。我修改了我的示例。
    【解决方案2】:

    尝试将以下属性添加到 IsActive 属性,看看是否有帮助

    [NotMapped]
    

    更新

    使用 Data Annotations 代替更容易掌握和使用 IMO 的 fluent API

    首先从你的上下文类中移除 OnModelCreating 函数

    然后像这样定义你的模型

    [Table("Bank")]
    public class Bank
    {
        [key]
        public int Id { get; set; }
        [Column("BankName")]
        public string Name { get; set; }
        [NotMapped]
        public bool IsActive { get; set; }
    }
    

    这将按预期工作

    【讨论】:

    • 如果选择中的列名与表中的列名不对应,我看不出这会有什么帮助。
    • 这表示该属性不需要映射,并且在数据库中不存在....试试这个,它会解决你的问题
    • 您需要做的另一件事是将您的 Name 属性更改为 BankName 以确保它与相应的列匹配
    • 我不能使用 fluent API 将列映射到属性,而不是更改我的域名属性?
    • 数据注解打破了实体类(模式)的单一责任原则,是旧 ActiveRecord 反模式开发者的雏形。
    【解决方案3】:

    您可以使用 System.ComponentModel.DataAnnotations 映射属性名称以匹配现有表中的名称,例如

        [Column("BankID")]
        [Required]
        public string Id
            {
            get;
            set;
            }
    

    【讨论】:

    • 是的,我想是的,尝试添加类似 modelBuilder.Entity().Property(bank => bank.ID).HasColumnName("BankID");到您的 DbContext OnModelCreating 覆盖。
    猜你喜欢
    • 1970-01-01
    • 2016-02-13
    • 2011-02-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-06-21
    • 1970-01-01
    相关资源
    最近更新 更多