c# – 映射到现有数据库表
发布时间:2020-12-16 01:50:33 所属栏目:百科 来源:网络整理
导读:我首先使用Entity Framework 4.1代码连接到现有的数据库.我首先使用的表叫做Bank.我还有一个Bank类作为我的域模型.这是我映射我的类和表的方式: public class HbfContext : DbContext{ public DbSetBank Banks { get; set; } protected override void OnMod
我首先使用Entity Framework 4.1代码连接到现有的数据库.我首先使用的表叫做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) My Bank类看起来像这样: 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吗? 解决方法
您需要指示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"); (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |