Kodda, yorumlanması gereken kısım çözmem gereken şey ... LINQ'da böyle bir sorgu yazmanın bir yolu var mı? Buna ihtiyacım var çünkü Statü bazında sıralama ihtiyacım olacak.LINQ - koşul
var result = (
from contact in db.Contacts
join user in db.Users on contact.CreatedByUserID equals user.UserID
join deal in db.Deals on contact.ContactID equals deal.ContactID into deals
orderby contact.ContactID descending
select new ContactListView
{
ContactID = contact.ContactID,
FirstName = contact.FirstName,
LastName = contact.LastName,
Email = contact.Email,
Deals = deals.Count(),
EstValue = deals.Sum(e => e.EstValue),
SalesAgent = user.FirstName + " " + user.LastName,
Tasks = 7,
// This is critical part
if(Deals == 0) Status = "Prospect";
else
Status = "Client";
// End of critical part...
})
.OrderBy(filterQuery.OrderBy + " " + filterQuery.OrderType)
.Where(filterQuery.Status);
, Deal yerine deals.Count() olması gerekmiyor. Ya ikiden fazla vakam varsa, bunu yapmak mümkün mü? Teşekkürler! –
@ile - Kesinlikle, bazı parantezleri kullanmanız yeterli .. Durum = (Deals.Count() == 0? "Fırsat yok": (Deals.Count() == 1? "Tek anlaşma": "Birçok fırsatlar ")) –
Görüyorum ... bu gerçekten harika! Teşekkürler! –