Daten sortieren
Die Suchfunktion von CityBook Libraries funktioniert gut, aber Nutzer möchten die Ergebnisse nach Erscheinungsjahr entweder auf- oder absteigend sortieren. du baust die Abfrage dynamisch, damit beide Sortierrichtungen unterstützt werden.
Die Klasse HikariSetup ist bereits für dich konfiguriert.
Diese Übung ist Teil des Kurses
Abfragen einer PostgreSQL-Datenbank in Java
Anleitung zur Übung
- Vervollständige die Abfrage, um das Ergebnis nach
publication_yearzu sortieren. - Erweitere die Abfrage so, dass je nach der Benutzereingabe in der Variablen
ascendingauf- oder absteigend sortiert wird.
Interaktive Übung
Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.
public class Main {
public static void main(String[] args) throws SQLException {
HikariDataSource ds = HikariSetup.createDataSource();
boolean ascending = true;
// Order by the publication_year in ascending order
String query = """
SELECT *
FROM books
WHERE publication_year >= ?
AND status = 'available'
____ ____ ____
""";
// Sort depending on the ascending parameter
query += ____ ? "____" : "____";
try (Connection conn = ds.getConnection();
PreparedStatement pstmt = conn.prepareStatement(query)) {
pstmt.setInt(1, 2000);
try (ResultSet rs = pstmt.executeQuery()) {
while (rs.next()) {
System.out.printf("ID: %d, Title: %s (%d)%n", rs.getInt("book_id"), rs.getString("title"), rs.getInt("publication_year"));
}
}
}
}
}