LINQ - if 条件

标签 linq if-statement linq-to-sql

在代码中,注释部分是我需要解决的问题...有没有办法在 LINQ 中编写这样的查询?我需要这个,因为我需要根据状态进行排序。

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);

最佳答案

Status = (deals.Count() == 0 ? "Prospect" : "Client")

这使用 "Conditional operator"

The conditional operator (?:) returns one of two values depending on the value of a Boolean expression.

编辑:您可以进行如下组合:

Status = (deals.Count() == 0 ? "Prospect" : (deals.Count() == 1 ? "Client" : "Other"))

在本例中,您经常使用 deals.Count(),因此您可以使用 LINQ let 语法将结果存储在临时变量中:

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
   let dealCount = deals.Count()
   ... // Continue here
     Status = (dealCount == 0 ? "Prospect" : (dealCount == 1 ? "Client" : "Other"))

关于LINQ - if 条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3051786/

相关文章:

entity-framework - 如何在 Linq 的 Where 条件中使用 IN 运算符

vba - 如何在 Excel VBA 中使用 OR 和空单元格创建 IF 语句

java - 在方法中使用 for 循环检查字符串中的数组项 - 打印 12 行而不是 1 行

c# - 违反 PRIMARY KEY 约束 : Cannot insert duplicate key in object

c# - 从另一个列表更新列表 - Entity Framework

c# - 带有类型检查 C# 的更好的 If 语句

linq - 在 Linq 查询中使用自定义函数

c# - LINQ2SQL 中用于共享常用方法的抽象类

c# - 通过文本框更改过滤数据 GridView

c# - Linq UNION 查询选择两个元素