Grundlegende SQL-Abfragen ausführen

Abfragen einer PostgreSQL-Datenbank in Java

Miller Trujillo

Staff Software Engineer

Anweisungen in JDBC

  • Nutze executeQuery() für SELECT-Anweisungen
  • Nutze executeUpdate() für INSERT, UPDATE, DELETE

$$

Anweisung als Bote

Abfragen einer PostgreSQL-Datenbank in Java

Eine Anweisung erstellen

String sql = "SELECT book_id, title, publication_year FROM books";

try (Connection conn = DriverManager.getConnection(url, user, password); Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql)) {
Abfragen einer PostgreSQL-Datenbank in Java

Ergebnisse mit ResultSet lesen

String sql = "SELECT book_id, title, publication_year FROM books";
try (Connection conn = DriverManager.getConnection(url, user, password);
     Statement stmt = conn.createStatement();
     ResultSet rs = stmt.executeQuery(sql)) {

while (rs.next()) {
int id = rs.getInt("book_id"); String title = rs.getString("title"); int year = rs.getInt("publication_year"); System.out.println(id + " | " + title + " (" + year + ")");}}
1 | Effective Java (2018)
2 | Clean Code (2008)
...
Abfragen einer PostgreSQL-Datenbank in Java

Ausnahmen behandeln

try {
    Statement stmt = conn.createStatement();

stmt.executeQuery("SELECT * FROM unknown_table");
} catch (SQLException e) {
System.err.println("Fehler: " + e.getMessage()); System.err.println("SQLState: " + e.getSQLState()); }
Fehler: ERROR: relation "unknown_table" does not exist
  Position: 15
SQLState: 42P01
Abfragen einer PostgreSQL-Datenbank in Java

Zusammenfassung

  • Statement sendet SQL-Befehle an die Datenbank
  • ResultSet enthält Abfrageergebnisse, Schleife mit next()
  • Getter-Methoden: getInt(), getString(), getDate()
  • executeQuery() für SELECT, executeUpdate() für Änderungen
  • Fehler mit SQLException behandeln

Zusammenfassung

Abfragen einer PostgreSQL-Datenbank in Java

Lass uns üben!

Abfragen einer PostgreSQL-Datenbank in Java

Preparing Video For Download...