gpt4 book ai didi

c# - 映射到现有的数据库表

转载 作者:行者123 更新时间:2023-11-30 14:15:54 26 4
gpt4 key购买 nike

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

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 属性并映射其他属性。如果您不喜欢数据注释,您可以使用 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");

关于c# - 映射到现有的数据库表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8849178/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com