Linq-запрос с условным предложением WHERE

Я новичок в LINQ, поэтому извиняюсь заранее

У меня есть следующий запрос Linq:-

var OrdersByBranches =
    from a in AllOrders
    join b in AllBranchKeys
        on a.BranchKey equals b.BranchKey
    orderby a.Date
    group a by new { a.Date, a.paymentMethod } into BranchOrderGrouped
    select new
    {
        BranchOrderGrouped.Key.Date,
        CurrencyAmount = BranchOrderGrouped.Sum(a =>
        a.CurrencyAmount),
        BranchOrderGrouped.Key.paymentMethod
    };

Мне нужно включить предложение where в вышеупомянутый запрос... только если переменная с именем BranchKeySelected равна ""

Я попытался использовать оператор If Else и повторил тот же самый запрос, один из которых содержал предложение where, а другой - NOT. ... но когда я делаю это.. тогда OrdersByBranches НЕ доступен вне оператора IF

Буду благодарен за любую помощь

С уважением

привидение

2 ответа

var OrdersByBranches = 
    from a in AllOrders 
    join b in AllBranchKeys on a.BranchKey equals b.BranchKey 
    orderby a.Date 
    group a by new { a.Date, a.paymentMethod } into BranchOrderGrouped 
    select new { 
        BranchOrderGrouped.Key.Date, 
        CurrencyAmount = BranchOrderGrouped.Sum(a =>  a.CurrencyAmount), 
        BranchOrderGrouped.Key.paymentMethod 
    };

if(string.IsNullOrEmpty(BranchKeySelected ))
{
    OrdersByBranches = OrdersByBranches.Where(/*blbabla*/);
}

return OrdersByBranches; 

Попробуй (а мой linq не отполирован)

var OrdersByBranches = from a in AllOrders 
    join b in AllBranchKeys on a.BranchKey equals b.BranchKey 
    where b.BranchKeySelected.Contains("")
    orderby a.Date group a by new 
        {
            a.Date, 
            a.paymentMethod
        }
        into BranchOrderGrouped
    select new
        {
            BranchOrderGrouped.Key.Date, 
            CurrencyAmount = BranchOrderGrouped.Sum(a =>  a.CurrencyAmount),
            BranchOrderGrouped.Key.paymentMethod 
         };
Другие вопросы по тегам