Filtrer les groupes
La nouvelle fonctionnalité de statistiques des notes de la Metropolitan Public Library fait un carton ! Cependant, des usagers se plaignent que les livres avec une ou deux critiques seulement peuvent afficher des moyennes trompeuses. Un livre avec un unique avis 5 étoiles semble aussi bien noté qu’un classique plébiscité avec des centaines d’avis positifs.
La directrice de la bibliothèque vous a demandé d’améliorer le système en permettant aux utilisateurs d’exclure les livres qui n’ont pas assez de critiques.
Cet exercice fait partie du cours
<cours>Interroger une base de données PostgreSQL en Java</cours>Instructions de l’exercice
- Complétez la requête pour filtrer les livres selon un nombre de critiques spécifié.
- Définissez le paramètre de manière sécurisée afin d’afficher uniquement les livres ayant au moins trois critiques.
Exercice interactif pratique
Essayez cet exercice en complétant ce code d’exemple.
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"));
}
}
}
}
}