Heim > Java > javaLernprogramm > Wie führt man verschachtelte GroupBy-Operationen in Java 8 für die komplexe Datenaggregation durch?

Wie führt man verschachtelte GroupBy-Operationen in Java 8 für die komplexe Datenaggregation durch?

Patricia Arquette
Freigeben: 2024-10-24 08:50:02
Original
636 Leute haben es durchsucht

How to Perform Nested GroupBy Operations in Java 8 for Complex Data Aggregation?

Verschachteltes (mehrstufiges) GroupBy in Java 8

Mehrstufige Gruppierung in Java 8 ermöglicht eine komplexe Aggregation von Datenobjekten basierend auf mehrere Felder. In Ihrem Fall haben Sie eine Reihe von Klassen Pojo, Item und SubItem und möchten Elemente basierend auf Schlüssel1 und dann Unterelemente innerhalb dieser Gruppe nach Schlüssel2 gruppieren.

Um dies zu erreichen, können wir nicht einfach Verwenden Sie verschachtelte Collectors.groupingBy-Aufrufe, da dies keine Gruppierung nach mehreren Schlüsseln aus verschiedenen Objekten ermöglichen würde. Stattdessen greifen wir auf eine Kombination aus flatMap und Gruppierungskollektoren zurück:

<code class="java">Map<T, Map<V, List<SubItem>>> result = pojo.getItems().stream()
    .flatMap(item -> item.getSubItems().stream()
        .map(sub -> new AbstractMap.SimpleImmutableEntry<>(item.getKey1(), sub)))
    .collect(Collectors.groupingBy(AbstractMap.SimpleImmutableEntry::getKey,
                Collectors.groupingBy(Map.Entry::getValue, Collectors.toList())));</code>
Nach dem Login kopieren

Bei diesem Ansatz verwenden wir zunächst flatMap, um einen Stream von Paaren zu erstellen, der den Schlüssel1 von jedem Element und das entsprechende Unterelement enthält. Dann wenden wir Collectors.groupingBy zweimal an: einmal, um die Paare nach Schlüssel1 zu gruppieren, und noch einmal, um die Unterelemente nach Schlüssel2 zu gruppieren.

Eine alternative Lösung wäre, einen benutzerdefinierten Kollektor zu definieren, der eine FlatMapping-Operation ähnlich wie bei Java 9 bereitstellt Collectors.flatMapping:

<code class="java">static <T,U,A,R> Collector<T,?,R> flatMapping(
    Function<? super T,? extends Stream<? extends U>> mapper,
    Collector<? super U,A,R> downstream) {

    BiConsumer<A, ? super U> acc = downstream.accumulator();
    return Collector.of(downstream.supplier(),
        (a, t) -> { try(Stream<? extends U> s=mapper.apply(t)) {
            if(s!=null) s.forEachOrdered(u -> acc.accept(a, u));
        }},
        downstream.combiner(), downstream.finisher(),
        downstream.characteristics().toArray(new Collector.Characteristics[0]));
}</code>
Nach dem Login kopieren

Mit diesem benutzerdefinierten Collector kann der Gruppierungsvorgang vereinfacht werden:

<code class="java">Map<T, Map<V, List<SubItem>>> result = pojo.getItems().stream()
    .collect(Collectors.groupingBy(Item::getKey1,
                Collectors.flatMapping(item -> item.getSubItems().stream(),
                    Collectors.groupingBy(SubItem::getKey2))));</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie führt man verschachtelte GroupBy-Operationen in Java 8 für die komplexe Datenaggregation durch?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage