映射到已存在的数据库表
本文关键字:数据库 存在 映射 | 更新日期: 2023-09-27 18:20:23
我正在使用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吗?
您需要指示EF忽略IsActive
属性并映射其他属性。如果你不喜欢数据注释,你可以用流利的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");
尝试将以下属性添加到IsActive属性,看看它是否有助于
[NotMapped]
更新
使用数据注释,而不是更容易掌握和使用IMO 的流畅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; }
}
这将按预期工作
您可以使用System.ComponentModel.DataAnnotations来映射属性名称,以匹配现有表中的属性名称,例如
[Column("BankID")]
[Required]
public string Id
{
get;
set;
}