Список C# <> Значения GroupBy 2

На самом деле очень сложно реализовать GetHashCode() правильно, потому что, помимо уже упомянутых правил Marc, хэш-код не должен меняться в течение всего жизненного цикла объекта. Поэтому поля, которые используются для вычисления хэш-кода, должны быть неизменными.

Наконец-то я нашел решение этой проблемы, когда я работал с NHibernate. Мой подход заключается в вычислении хеш-кода из идентификатора объекта. Идентификатор может быть установлен только с помощью конструктора, поэтому, если вы хотите изменить ID, что очень маловероятно, вам нужно создать новый объект с новым идентификатором и, следовательно, новый хэш-код. Этот подход лучше всего работает с GUID, потому что вы можете предоставить конструктор без параметров, который произвольно генерирует ID.

34
задан SaaS Developer 12 December 2008 в 18:10
поделиться

3 ответа

var sums = Orders.GroupBy(x => new { x.CustomerID, x.ProductID })
                 .Select(group => group.Sum(x => x.ProductCount));
57
ответ дан Omar 10 October 2019 в 13:59
поделиться

С другой стороны, если Вы хотите получить идентификаторы для каждой суммы, Вы могли бы сделать это

var customerAndProductGroups =
    from order in Orders
    orderby order.CustomerID, order.ProductID // orderby not necessary, but neater
    group order by new { order.CustomerID, order.ProductID };

foreach (var customerAndProductGroup in customerAndProductGroups)
{
    Console.WriteLine("Customer {0} has ordered product {1} for a total count of {2}",
        customerAndProductGroup.Key.CustomerID,
        customerAndProductGroup.Key.ProductID,
        customerAndProductGroup.Sum(item => item.ProductCount));
}
7
ответ дан Klas Mellbourn 10 October 2019 в 13:59
поделиться

Я понимаю, что эта ветка очень старая, но, поскольку я просто боролся с этим синтаксисом, я решил опубликовать свои дополнительные результаты - вы можете вернуть сумму и идентификаторы (без foreach) в одном запросе следующим образом:

var sums = Orders
            .GroupBy(x => new { x.CustomerID, x.ProductID })
            .Select(group =>new {group.Key, ProductCount = group.Sum(x => x.ProductCount)});

Сложность для меня, чтобы заставить его работать, заключается в том, что сумма должна иметь псевдоним, очевидно ...

16
ответ дан 27 November 2019 в 16:25
поделиться
Другие вопросы по тегам:

Похожие вопросы: