Bre*_*ogt 3 c# entity-framework ef-code-first ef-fluent-api
我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");
}
}
Run Code Online (Sandbox Code Playgroud)
我的银行表:
BankID INT
BankName VARCHAR(50)
Run Code Online (Sandbox Code Playgroud)
My Bank类看起来像这样:
public class Bank
{
public int Id { get; set; }
public string Name { get; set; }
public bool IsActive { get; set; }
}
Run Code Online (Sandbox Code Playgroud)
当我想要归还所有银行时,我遇到了问题.从以下位置返回的SQL语句:
return db.Banks
.OrderBy(x => x.Name);
Run Code Online (Sandbox Code Playgroud)
是:
SELECT
[Extent1].[Id] AS [Id],
[Extent1].[Name] AS [Name],
[Extent1].[IsActive] AS [IsActive]
FROM
[dbo].[Bank] AS [Extent1]
ORDER BY
[Extent1].[Name] ASC
Run Code Online (Sandbox Code Playgroud)
这不起作用,因为我的表没有Id,Name和IsActive列.我该如何解决这个问题,EF会自动将BankId映射到Id和BankName吗?
您需要指示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");
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
7707 次 |
| 最近记录: |