LoslegenKostenlos loslegen

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

Kurs anzeigen

Anleitung zur Übung

  • Vervollständige die Abfrage, um das Ergebnis nach publication_year zu sortieren.
  • Erweitere die Abfrage so, dass je nach der Benutzereingabe in der Variablen ascending auf- 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"));
                }
            }
        }
    }
}
Code bearbeiten und ausführen