簡體   English   中英

LINQ in Entity Framework 6 with large .Any()

[英]LINQ in Entity Framework 6 with large .Any()

我有一個EF6查詢,它獲取ID列表並執行查詢:

public IList<Audit> AuditsByIDs(List<int> ids)
{
    return _db.Audits
        .Include(p => p.User)
        .Where(p => ids.Any(i => i == p.Id)).ToList();
}

它適用於少量的ID ,但當達到數百時,我得到錯誤:

SQL語句的某些部分嵌套得太深。 重寫查詢或將其分解為較小的查詢。

如何讓查詢只返回傳入的ID 我無法更改數據庫:(

使用Contains代替:

public IList<Audit> AuditsByIDs(List<int> ids)
{
    return _db.Audits
        .Include(p => p.User)
        .Where(p => ids.Contains(p.Id)).ToList();
}

哪個應該在生成的SQL查詢中轉換為IN

暫無
暫無

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

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