Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/23: Рейтинг темы: голосов - 23, средняя оценка - 4.83
128 / 1 / 0
Регистрация: 14.10.2007
Сообщений: 122
.NET 4.x

Linq Группировка

14.09.2010, 14:43. Показов 4594. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как сделать в linq группировку?

C#
1
2
3
var groupQuery = from p in db.Distributions
                  group p by p.Name into groupName
                  select new { groupName.ToList() };
Error 2 Invalid anonymous type member declarator.
Anonymous type members must be declared with a member assignment, simple name or member access.
Ошибка в этой строчке select new { groupName.ToList() };
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
14.09.2010, 14:43
Ответы с готовыми решениями:

Linq или не Linq. Linq медленней стандартных методов?
Есть у нас два массива, нужно найти совпадения в первом из второго. Два варианта реализации, первый костылем, второй с linq, но скорость...

LINQ to Interbase/Firebird и вообще LINQ to...
Возникла вот надобность работы с СУБД Interbase. Очень хочется пользоваться удобными средствами LINQ. В Сети нашелся ADO.NET provider for...

Группировка списка
Как в Visual Studio сделать группировку списка как на этой картинке?

10
 Аватар для kirill29
2098 / 1263 / 173
Регистрация: 01.02.2009
Сообщений: 2,842
14.09.2010, 15:06
Может так:
C#
1
var groupQuery = db.Distributions.GroupBy(p => p.Name).ToList();
0
Padawan
 Аватар для Johnny_D
473 / 323 / 30
Регистрация: 30.01.2010
Сообщений: 1,841
14.09.2010, 15:06
Примеры
0
 Аватар для kirill29
2098 / 1263 / 173
Регистрация: 01.02.2009
Сообщений: 2,842
14.09.2010, 15:16
Вот еще эту тему посмотрите: https://www.cyberforum.ru/csha... 83660.html
0
128 / 1 / 0
Регистрация: 14.10.2007
Сообщений: 122
14.09.2010, 15:27  [ТС]
Цитата Сообщение от kirill29 Посмотреть сообщение
Может так:
C#
1
var groupQuery = db.Distributions.GroupBy(p => p.Name).ToList();
Нет, не работает.

Добавлено через 36 секунд
Цитата Сообщение от kirill29 Посмотреть сообщение
Вот еще эту тему посмотрите: https://www.cyberforum.ru/csha... 83660.html
Там группировки нету.
0
 Аватар для kirill29
2098 / 1263 / 173
Регистрация: 01.02.2009
Сообщений: 2,842
14.09.2010, 15:30
db.Distributions - это что и как выглядит структура?
0
128 / 1 / 0
Регистрация: 14.10.2007
Сообщений: 122
14.09.2010, 15:35  [ТС]
Цитата Сообщение от kirill29 Посмотреть сообщение
db.Distributions - это что и как выглядит структура?
Таблица: Distributions
Поля: id / Name / kol_pack / version
0
 Аватар для kirill29
2098 / 1263 / 173
Регистрация: 01.02.2009
Сообщений: 2,842
14.09.2010, 16:13
Вам точно нужна группировка, а не сортировка? Вот пример группировки (взят с msdn):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
class GroupSample1
{
    // The element type of the data source.
    public class Student
    {
        public string First { get; set; }
        public string Last { get; set; }
        public int ID { get; set; }
        public List<int> Scores;
    }
 
    public static List<Student> GetStudents()
    {
        // Use a collection initializer to create the data source. Note that each element
        //  in the list contains an inner sequence of scores.
        List<Student> students = new List<Student>
        {
           new Student {First="Svetlana", Last="Omelchenko", ID=111, Scores= new List<int> {97, 72, 81, 60}},
           new Student {First="Claire", Last="O'Donnell", ID=112, Scores= new List<int> {75, 84, 91, 39}},
           new Student {First="Sven", Last="Mortensen", ID=113, Scores= new List<int> {99, 89, 91, 95}},
           new Student {First="Cesar", Last="Garcia", ID=114, Scores= new List<int> {72, 81, 65, 84}},
           new Student {First="Debra", Last="Garcia", ID=115, Scores= new List<int> {97, 89, 85, 82}} 
        };
 
        return students;
 
    }
 
    static void Main()
    {
        // Obtain the data source.
        List<Student> students = GetStudents();
 
        // Group by true or false.
        // Query variable is an IEnumerable<IGrouping<bool, Student>>
        var booleanGroupQuery =
            from student in students
            group student by student.Scores.Average() >= 80; //pass or fail!
 
        // Execute the query and access items in each group
        foreach (var studentGroup in booleanGroupQuery)
        {
            Console.WriteLine(studentGroup.Key == true ? "High averages" : "Low averages");
            foreach (var student in studentGroup)
            {
                Console.WriteLine("   {0}, {1}:{2}", student.Last, student.First, student.Scores.Average());
            }
        }
 
        // Keep the console window open in debug mode.
        Console.WriteLine("Press any key to exit.");
        Console.ReadKey();
    }
}
0
128 / 1 / 0
Регистрация: 14.10.2007
Сообщений: 122
14.09.2010, 17:34  [ТС]
Группировка и сортировка это абсолютные разные вещи.



C#
1
2
3
4
5
DataClasses1DataContext db = new DataClasses1DataContext(str);
 var myQuery = from p in db.Distributions
                          select new {p.Name };
 listBox1.ValueMember = "Name";
 listBox1.DataSource = groupQuery;
Этот запрос работает.


C#
1
2
3
4
5
6
 DataClasses1DataContext db = new DataClasses1DataContext(str);
var groupQuery = from p in db.Distributions
                             group p by p.Name into groupName
                             select new { groupName.ToList() };
 listBox1.ValueMember = "Name";
 listBox1.DataSource = groupQuery;
(Выводит тип данных)
Почему этот запрос не работает?
0
61 / 60 / 10
Регистрация: 11.08.2010
Сообщений: 199
15.09.2010, 10:15
Вот так будет работать:
C#
1
2
3
4
5
6
7
NorthWindDataContex db = new NorthWindDataContex();
            var custs = (from customer in db.Customers
                         group customer by customer.City).ToList();
 
            listBox1.DisplayMember = "Key";
            listBox1.ValueMember = "Key";
            listBox1.DataSource = custs;
Ты в блоке неявной инициализации объекта пытаешься результат своего запроса привести к листу:
C#
1
select new { groupName.ToList() };
конечно оно не будет работать.

group by возвращает IEnumerable<IGrouping<K, E>> т.е. в твоем случае это какие-то объекты, сгруппированные по ключу Name. Т.к. возвращается IEnumerable<IGrouping<K, E>>, то и в DisplayMember стоит именно "Key" а не "Name", но мне кажется ты здесь с помощью group by хотел выбрать просто не повторяющееся записи, это следует делать при помощи Distinct:
C#
1
2
3
4
5
6
7
NorthWindDataContex db = new NorthWindDataContex();
            var custs = (from customer in db.Customers
                         select new {Name = customer.City}).Distinct();
 
            listBox1.DisplayMember = "Name";
            listBox1.ValueMember = "Name";
            listBox1.DataSource = custs;
0
25 / 24 / 13
Регистрация: 04.07.2012
Сообщений: 463
14.01.2013, 20:57
Может поможите пожалуйста
Таблица: как сделать, чтоб добавлялось еще два столбца,а не проводилась группировка
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.01.2013, 20:57
Помогаю со студенческими работами здесь

Группировка и обновление c#
Все привет. В моей dataGriedVew есть некоторое количество записей, которые я хочу расположить в порядке возрастания некоторого столбца...

Группировка данных в запросе
Направьте пожалуйста на нужный путь. Есть таблица под названием &quot;Реализация&quot;. Туда пользователь вписывает имя,количество,поставщика,цену и...

Группировка данных в таблице
Ребята помогите разобраться. Как получить подобный результат? Не могу понять как группировать данные по производителю и вывести информацию...

Группировка данных datagridview
Имеется БД, в которой хранятся числовые данные. Деление происходит по месяцам. Как можно сгрупировать данные первого столбца, т.к. они...

Группировка элементов управления
Есть какой-нибудь элемент в ASP.NET с помощью которого можно было бы сгруппировать контролы на веб-форме, как показано на данном рисунке?...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru