我使用 ASP.NET5 和 Entity Framework 7.0.0-beta 5 创建了一个 API。
我创建了模型、DbContext 和存储库,当我尝试从数据库检索数据时,我得到了除外键数据之外的所有数据。
外键值始终为空。
数据库上下文
public class MrBellhopContext : DbContext
{
public DbSet<Company> Company { get; set; }
public DbSet<CompanyStatus> CompanyStatus { get; set; }
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Company>().Table("Company");
modelBuilder.Entity<Company>().Key(c => c.CompanyId);
modelBuilder.Entity<Company>().Index(c => c.Name);
modelBuilder.Entity<Company>().Reference(c => c.Status).InverseReference().ForeignKey<CompanyStatus>(c => c.StatusId);
modelBuilder.Entity<CompanyStatus>().Table("CompanyStatus");
modelBuilder.Entity<CompanyStatus>().Key(c => c.StatusId);
base.OnModelCreating(modelBuilder);
}
}
Model
public class Company
{
public int CompanyId { get; set; }
public string Name { get; set; }
public string Email { get; set; }
public CompanyStatus Status { get; set; }
public DateTime CreatedAt { get; set; }
public DateTime UpdatedAt { get; set; }
}
存储库(仅获取所有方法)
public IEnumerable<Company> GetAll()
{
return _dbcontext.Company.ToList();
}
使用 HTTP GET 检索数据我获取了所有数据,但外键的值为空:
JSON 响应:
0: {
CompanyId: 1
Name: "Hotel Amura"
Email: "[email protected]"
Status: null
CreatedAt: "2015-01-01T00:00:00"
UpdatedAt: "2015-01-01T00:00:00"
}
有谁知道如何使用EF7查询获取外键表数据?
EF7 中尚未实现延迟加载。请使用以下查询来立即加载相关实体。
_dbcontext.Company.Include(c => c.Status).ToList();
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)