IniziaInizia gratis

Riepilogare i dati

Sei uno sviluppatore della Metropolitan Public Library. Il bibliotecario capo ha richiesto una nuova funzionalità per il catalogo online: mostrare le statistiche delle valutazioni per ogni libro, così da aiutare gli utenti a scegliere cosa leggere in modo informato. Al momento, il sistema memorizza le singole recensioni nella tabella book_reviews; tuttavia, non c’è modo di vedere il numero totale di recensioni ricevute da un libro o la sua valutazione media.

Il tuo compito è scrivere una query che riepiloghi i dati delle recensioni calcolando il numero totale di recensioni e la valutazione media per ciascun libro.

Questo esercizio fa parte del corso

Eseguire query su un database PostgreSQL in Java

Visualizza il corso

Istruzioni dell'esercizio

  • Completa la query per contare il numero di recensioni e calcolare la valutazione media.
  • Raggruppa i risultati per book_id per ottenere le statistiche di ciascun libro.

Esercizio pratico interattivo

Prova a risolvere questo esercizio completando il codice di esempio.

public class Main {
    public static void main(String[] args) throws SQLException {
        HikariDataSource ds = HikariSetup.createDataSource();
        String query = """
            --  Count the number of reviews and the average rating
            SELECT book_id, ____(*), ____(rating)
            FROM book_reviews
            -- Group reviews by book_id
            ____ ____ ____;
            """;

        try (Connection conn = ds.getConnection();
             PreparedStatement pstmt = conn.prepareStatement(query);
             ResultSet rs = pstmt.executeQuery()) {
            while (rs.next()) {
                System.out.printf("ID: %d, Count: %d, Average: %.0f%n",
                        rs.getInt("book_id"), rs.getInt("count"), rs.getDouble("avg"));
            }
        }
    }
}
Modifica ed esegui il codice