LINQ group by-Abfrage verwenden reflektiert Eigenschaft name

Will ich füllen Sie ein drop-down mit den öffentlichen Eigenschaften eines bestimmten Objekts, das habe ich fein gemacht. Aber jetzt, wenn der Benutzer wählt den Wert aus dem dropdown, ich will es zu der Gruppe der DB-Tabelle, die Ergebnisse nach dieser Spalte. Ich habe versucht mit LINQ, aber ich kann nur herausfinden, wie man explizit die Gruppe durch eine Instanz-Variablen-Eigenschaft, die nicht durch eine Reflexion Eigenschaft. Das ist meine Methode - der parameter ist der string, der den Namen der Eigenschaft an. ZB, es wird "Land", wenn der Nutzer will, um group by Kunde.Land, es wird "State", wenn der Nutzer will, um group by Kunde.Zustand. Aber im moment muss ich hart codiert Gruppe von "Staat", da ich nicht herausfinden, wie die Verwendung der string-Wert übergeben, mit meiner LINQ-Abfrage

private void DisplayReportAction(string category)
{
    if (!string.IsNullOrEmpty(category))
    {
        SelectedCategory = category;
        _summaries.Clear();

        foreach (var custGroup in _customerInterface.CustomerInterface.GetAllCustomers().GroupBy(c => c.State)
            .Select(group => new
                                 {
                                     Category = group.Key,
                                     Count = group.Count()
                                 })
                                 .OrderBy(x => x.Category))
        {
            _summaries.Add(new CustomerReportSummaryViewModel(custGroup.Category, custGroup.Count));
        }

        ReportVisibility = Visibility.Visible;
    }
}
InformationsquelleAutor NZJames | 2013-10-23
Schreibe einen Kommentar