我有一个关于LINQ查询的问题。通常,查询返回IEnumerable<T>类型。如果返回值为空,不确定是否为空。我不确定如果下面的ToList()将抛出一个异常或只是一个空列表<string>如果没有发现IEnumerable结果?

   List<string> list = {"a"};
   // is the result null or something else?
   IEnumerable<string> ilist = from x in list where x == "ABC" select x;
   // Or directly to a list, exception thrown?
   List<string> list1 = (from x in list where x == "ABC" select x).ToList();

我知道这是一个非常简单的问题,但是我暂时没有VS可用。


当前回答

在Linq-to-SQL中,如果你试图在查询中获得第一个元素而没有结果,你会得到序列不包含元素错误。我可以向你保证,上面提到的错误不等于对象引用没有设置为对象的实例。 总之,不,它不会返回null,因为null不能说序列不包含任何元素,它总是说对象引用没有设置为对象的实例;)

其他回答

var lst = new List<int>() { 1, 2, 3 };
var ans = lst.Where( i => i > 3 );

(ans == null).Dump();  // False
(ans.Count() == 0 ).Dump();  // True

(Dump来自LinqPad)

这里的其他帖子已经明确表示,结果是一个“空”的IQueryable, ToList()将正确地更改为一个空列表等。

一定要小心一些操作符,因为如果你给它们发送一个空的枚举对象,它们就会抛出。当你把它们串在一起时就会发生这种情况。

在Linq-to-SQL中,如果你试图在查询中获得第一个元素而没有结果,你会得到序列不包含元素错误。我可以向你保证,上面提到的错误不等于对象引用没有设置为对象的实例。 总之,不,它不会返回null,因为null不能说序列不包含任何元素,它总是说对象引用没有设置为对象的实例;)

它将返回一个空的枚举对象。它不是空的。你可以睡觉的声音:)

你也可以检查.Any()方法:

if (!YourResult.Any())

只是注意.Any仍然会从数据库中检索记录;执行.FirstOrDefault()/.Where()将会有同样多的开销,但你将能够捕获从查询返回的对象