IniziaInizia gratis

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

Visualizza il corso

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"));
                }
            }
        }
    }
}
Modifica ed esegui il codice