3

我正在使用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 吗?

4

3 回答 3

5

您需要指示 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");
于 2012-01-13T10:52:41.167 回答
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; }
}

这将按预期工作

于 2012-01-13T10:42:05.567 回答
0

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

    [Column("BankID")]
    [Required]
    public string Id
        {
        get;
        set;
        }
于 2012-01-13T10:45:04.263 回答