簡體   English   中英

Linq2db:通過預先加載連接表

[英]Linq2db: join tables with eager loading

我在我的項目中使用 linq2db ORM 並具有以下數據庫模式(簡化):

在此處輸入圖像描述

我有以下方法來獲取有關用戶的信息:

public async Task<User> GetUser(int id)
{
  var user =
    await (
        from u in _db.Users
                     .LoadWith(u => u.Accounts)
                     .ThenLoad(a => a.Transactions)
        where u.Id == id
        from lang in _db.Languages.LeftJoin(l => l.Id == u.LanguageId)
        select u)
      .FirstOrDefaultAsync();

  return user;
}

但是,我想獲取有關每個帳戶的所有限制和聚合器的信息。 我相信應該有一種有效的方法來做到這一點。 有人可以幫我嗎?

當我們使用LoadWith()時,使用ThenLoad()之后,它會從根( User表)開始,像這樣:

from u in _db.Users
                 .LoadWith(u => u.Accounts)
                    .ThenLoad(a => a.Transactions)
                 .LoadWith(u => u.Accounts)
                    .ThenLoad(a => a.Limits)
                 .LoadWith(u => u.Accounts)
                    .ThenLoad(a => a.Aggregators);

您還可以使用Include()ThenInclude()而不是LoadWith()ThenLoad() 包含與加載

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM