如何使用LINQ从SQL Server获取唯一的首字母名称和名称开头?

时间:2009-05-16 17:43:53

标签: vb.net linq grouping

几天前我在玩ASP.NET MVC 1.0。我从一个名为“Contacts”的表DB开始,结构非常简单,例如标题,FullName,SurName,电子邮件,电话,地址等。

我正在使用LINQ作为我的模型。

在我的主视图中,我想显示一个字母表列表,其中包含以该字母开头的FullNames,以及FullNames的数量。有些类似如下所示:

A - (2)
D - (4)
J - (1)
等等。关于显示器的一个特别之处在于我不想显示那些没有以它们开头的名字的字母表。

我尝试了几个问题,但没有成功。 任何有助于解决此查询的帮助表示赞赏。请以VB.NET语言提供代码。

感谢。

3 个答案:

答案 0 :(得分:3)

    var query = from c in contacts
                group c by c.FullName[0] into cg
                select new { FirstChar = cg.Key, Count = cg.Count() };

应该有效

答案 1 :(得分:0)

MSDN上有一个非常相似的例子:

public void Linq41() {
            string[] words = { "blueberry", "chimpanzee", "abacus", "banana", "apple", "cheese" };

            var wordGroups =
                from w in words
                group w by w[0] into g
                select new { FirstLetter = g.Key, Words = g };

            foreach (var g in wordGroups) {
                Console.WriteLine("Words that start with the letter '{0}':", g.FirstLetter);
                foreach (var w in g.Words) {
                    Console.WriteLine(w);
                }
            }
        }

您必须在select语句中将Words = g更改为Count = g.Count,因此您只需查询组中项目的总和。

答案 2 :(得分:0)

在VB.NET中:

Dim FirstLetterCounts = From c In contacts _
                        Group c By Key = c(0) Into NameGroup _
                        Select FirstLetter = Key, Count = NameGroup.Count()

For Each g In FirstLetterCounts
    Console.WriteLine("First Letter = {0}, Count = {1}", g.Key, g.Count)
Next