1

这是我的代码。有用

var someField = "abc";

var list = Entities.Where(x=>SomeField).FirstOrDefault();

这就是问题所在,someField 也可以为 null 或 string.empty。如果 someField 为 null 或 string.empty,我将选择 SomeField 为 null 或 string.empty 的所有内容。

var list = Entities.Where(x=>SomeField  == null || SomeField == string.empty).FirstOrDefault();

现在,我有一个 if else 语句来检查 someField 是否有值,然后决定使用哪个查询。

我需要将 2 个查询合并为一个。因为如果有我们需要检查的字段,那么这个 if else 语句会变得很长。

4

2 回答 2

3

我怀疑您实际上想要 match x.SomeField == someField,或者如果someField为 null 或为空,则所有内容,对吗?

我会这样做:

var fetchAll = string.IsNullOrEmpty(someField);
var list = Entities.FirstOrDefault(x => fetchAll || x.SomeField == someField);

可以内联它,但我认为上面的内容比在查询中检查是否someField为空或为空更清楚。

请注意,我使用了FirstOrDefault带谓词的重载——这相当于使用Where后跟FirstOrDefault,但更简洁一些。

于 2012-10-24T16:33:49.930 回答
1

我做了一个小样本,我只是在 SomeField 中获取具有 null 或空值的实体......

我希望这对你有用。

public class MyEntity
{
    public int ID { get; set; }

    public string SomeField { get; set; }
}

static void Main(string[] args)
{
   List<MyEntity> Entities = new List<MyEntity>();
   for (int i = 0; i < 10; i++)
   {
       Entities.Add(new MyEntity()
                   {
                       ID = i,
                       SomeField = "Value " + i.ToString()
                   });
   }

   Entities.Add(new MyEntity() { ID = 10, SomeField = null });
   var entity = Entities.Where(x => string.IsNullOrEmpty(x.SomeField)).FirstOrDefault();
}
于 2012-10-24T16:44:11.497 回答