LINQ是。net自泛型以来最大的改进之一,它为我节省了大量的时间和代码。然而,对我来说,流畅的语法似乎比查询表达式语法更自然。

var title = entries.Where(e => e.Approved)
    .OrderBy(e => e.Rating).Select(e => e.Title)
    .FirstOrDefault();

var query = (from e in entries
             where e.Approved
             orderby e.Rating
             select e.Title).FirstOrDefault();

两者之间有什么区别吗?或者两者之间有什么特别的好处吗?


当前回答

虽然我确实理解并喜欢流畅的格式,但出于可读性的原因,我暂时坚持使用Query。刚接触LINQ的人会发现Query读起来要舒服得多。

其他回答

当我可以用这种方式编写整个表达式时,我更喜欢使用后者(有时称为“查询理解语法”)。

var titlesQuery = from e in entries
                  where e.Approved
                  orderby e.Rating
                  select e.Titles;

var title = titlesQuery.FirstOrDefault();

只要我必须添加(括号)和. methodcalls(),我就会改变。

当我使用前者时,我通常每行放一个子句,像这样:

var title = entries
    .Where (e => e.Approved)
    .OrderBy (e => e.Rating)
    .Select (e => e.Title)
    .FirstOrDefault();

我觉得这样更容易理解。

流畅的语法确实看起来更强大,它也应该更好地将代码组织成小的可重用方法。

我更喜欢查询语法,因为我来自使用SQL的传统web编程。这对我来说更容易理解。然而,它认为我将开始使用. where (lambda),因为它肯定更短。

我完全不懂查询语法。在我看来,没有理由这么做。let可以通过. select和匿名类型来实现。我只是觉得在里面加上标点符号看起来更有条理。

流畅的界面,如果只有一个位置的话。如果我需要选择或排序,我通常使用Query语法。