c# - C# EntityFramework 包含引用及其引用,如何?
问题描述
我正在使用 .NET Core 2.0
我确实有3个模型:
class ModelA {
[Key]
public int ID { get; set; }
public List<ModelB> Emails { get; set; }
}
class ModelB {
[Key]
public int ID { get; set; }
public string Name { get; set; }
public int RequestId { get; set; }
public ModelA Request { get; set; }
public List<ModelC> Tokens { get; set; }
}
class ModelC {
[Key]
public int ID { get; set; }
public string Token { get; set; }
public int Status { get; set; }
public string getStatusName()
{
string[] Statuses = new string[] {
"Created", // 0
"Approved", // 1
"Rejected" // 2
};
return Statuses[Status];
}
}
我也有这样创建的上下文:
public class RequestorContext : DbContext
{
public DbSet<ModelA> Request { get; set; }
public DbSet<ModelB> Email { get; set; }
public DbSet<ModelC> Token { get; set; }
public RequestorContext(DbContextOptions<RequestorContext> options) : base(options)
{
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
}
}
现在我想在控制器中做这样的事情:
var request = await _context.Request
.Include(r => r.Emails) //also include tokens - how ???
.SingleOrDefaultAsync(r => r.Id == id);
那么基本上如何在电子邮件中包含相应的令牌? 为了能够在视图中做这样的事情:
@foreach (var email in Model.Emails)
{
<tr>
<td>@email.Name</td>
<td>@email.Token.Token</td>
<td>@email.Token.getStatusName()</td>
</tr>
}
目前我收到这样的错误:
RuntimeBinderException:无法对空引用执行运行时绑定 CallSite.Target(Closure , CallSite , object ) System.Dynamic.UpdateDelegates.UpdateAndExecute1(CallSite site, T0 arg0) AspNetCore._Views_Requestor_Details_cshtml+d__8.MoveNext() in Details.cshtml + @email .Token.getStatusName()
解决方案
要加载多个级别的相关数据,请使用此处ThenInclude
记录的内容。
要解决您的问题,您的代码将如下所示:
var request = await _context.Request
.Include(r => r.Emails)
.ThenInclude(e => e.Tokens)
.SingleOrDefaultAsync(r => r.Id == id);
推荐阅读
- c# - 从可为空的变量中获取类型
- c# - 导致对象实例化并添加到集合的 Zip 列表
- java - 使用 HttpsURLConnection 时 HTTPS GET 请求中的额外数据?
- c# - 如何从 C# 中的 pastebin raw 之类的网站加载代码
- java - 有没有办法使用 JaCoCo Java API 检测 jar 文件?
- c# - Visual Studio Intellisense 找不到一个基类
- java - JPA - 另一个表中使用的多对多主键
- python-3.x - 带有 Python 3.6 ImageTk 的 MacOS 不显示图像
- delphi - Delphi 内联使用导致“F2084 内部错误”
- c# - 如何使用 ClosedXML 从 excel 文件中读取单元格值