LoslegenKostenlos loslegen

Buch-Suchsystem

Die aktuelle Suche von CityBook Libraries unterstützt nur exakte Buchtitel. Sie brauchen eine flexible Suche, mit der Besucher nach Teilstrings im Titel, nach Autorennamen oder nach einer Kombination dieser Kriterien suchen können.

Du erstellst einen dynamischen Query-Builder, der SQL-Abfragen basierend auf den von Nutzern angegebenen Suchkriterien zusammenstellt. 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

  • Hänge die Titelbedingung an die Abfrage an.
  • Füge der Abfrage AND hinzu, wenn du eine Titelbedingung hinzugefügt hast, sonst WHERE.
  • Vervollständige die Abfrage, um nach dem Titel zu sortieren.

Interaktive Übung

Vervollständige den Beispielcode, um diese Übung erfolgreich abzuschließen.

public class Main {
    public static void main(String[] args) {
        String titleSearch = "first";
        String authorSearch = null;

        StringBuilder sql = new StringBuilder(
                "SELECT b.title, a.first_name AS author " +
                        "FROM books b " +
                        "JOIN book_authors ba ON b.book_id = ba.book_id " +
                        "JOIN authors a ON ba.author_id = a.author_id ");
        boolean hasTitleSearch = false;

        if (titleSearch != null && !titleSearch.isEmpty()) {
            // Append the title condition
            sql.____("WHERE b.title ILIKE ? ");
            hasTitleSearch = true;
        }

        if (authorSearch != null && !authorSearch.isEmpty()) {
            // Add AND if you added title condition or WHERE if not
            sql.append(hasTitleSearch ? "AND " : "____");
            sql.append(" a.first_name ILIKE ? ");
        }

        // Complete the query to sort by title
        sql.append("____ ____ b.title");

        System.out.println(sql);
    }
}
Code bearbeiten und ausführen