Filtrare i gruppi
La nuova funzione di statistiche sui punteggi della Metropolitan Public Library è un successo! Tuttavia, alcuni utenti hanno segnalato che i libri con una o due recensioni possono avere medie fuorvianti. Un libro con una singola recensione da 5 stelle sembra valutato quanto un classico amatissimo con centinaia di recensioni positive.
La direttrice della biblioteca ti ha chiesto di migliorare il sistema permettendo agli utenti di escludere i libri con un numero insufficiente di recensioni.
Questo esercizio fa parte del corso
Eseguire query su un database PostgreSQL in Java
Istruzioni dell'esercizio
- Completa la query per filtrare i libri con un numero specificato di recensioni.
- Imposta in modo sicuro il parametro per mostrare solo i libri con almeno tre recensioni.
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 = """
SELECT book_id, COUNT(*), AVG(rating)
FROM book_reviews
GROUP BY book_id
-- Filter books with a specified number of reviews
____ count(*) >= ?
""";
try (Connection conn = ds.getConnection();
PreparedStatement pstmt = conn.prepareStatement(query)) {
// Display books with at least three reviews
pstmt.____(____, ____);
try (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"));
}
}
}
}
}