如何从linq查询中获取字符串列表?

时间:2011-06-14 16:40:57

标签: linq

我正在考虑从linq查询中获取列表,但我不知道如何。请帮忙。

我的代码如下,但不正确。

public List<string> SearchName(string pre)
{
    VettingDataContext dc = new VettingDataContext(_connString);
    List<string> query = (from a in dc.Accounts
                          where (a.FirstName + " " + a.LastName).StartsWith(pre)
                          select new {Name = a.FirstName + " " + a.LastName }).Distinct().ToList();
}

3 个答案:

答案 0 :(得分:3)

尝试简单地选择一个字符串值:

public List<string> SearchName(string pre)
{
    VettingDataContext dc = new VettingDataContext(_connString);
    List<string> query = (from a in dc.Accounts
                          where (a.FirstName + " " + a.LastName).StartsWith(pre)
                          select (a.FirstName + " " + a.LastName)).Distinct().ToList();
}

答案 1 :(得分:2)

最好只评估一次名称(部分原因是因为这意味着避免重复自己) - 并且不得无故使用匿名类型:

public List<string> SearchName(string pre)
{
    VettingDataContext dc = new VettingDataContext(_connString);
    return dc.Accounts
             .Select(a => a.FirstName + " " + a.LastName)
             .Where(name => name.StartsWith(pre))
             .Distinct()
             .ToList();
}

请注意,这是我认为使用点表示法而不是查询表达式表示法更有意义的时候之一。

答案 2 :(得分:0)

你很亲密。尝试:

public List<string> SearchName(string pre)
{
    VettingDataContext dc = new VettingDataContext(_connString);
    List<string> query= (from a in dc.Accounts
                 where (a.FirstName + " " + a.LastName).StartsWith(pre)
                         select a.FirstName + " " + a.LastName)
                         .Distinct().ToList();
}