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
Istruzioni dell'esercizio
- Completa la query per contare il numero di recensioni e calcolare la valutazione media.
- Raggruppa i risultati per
book_idper 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"));
}
}
}
}