JDBC - Ergebnismengen

Die SQL-Anweisungen, die Daten aus einer Datenbankabfrage lesen, geben die Daten in einer Ergebnismenge zurück. Die SELECT-Anweisung ist die Standardmethode, um Zeilen aus einer Datenbank auszuwählen und in einer Ergebnismenge anzuzeigen. Die Schnittstelle java.sql.ResultSet repräsentiert die Ergebnismenge einer Datenbankabfrage.

Ein ResultSet-Objekt verwaltet einen Cursor, der auf die aktuelle Zeile in der Ergebnismenge zeigt. Der Begriff "Ergebnismenge" bezieht sich auf die in einem ResultSet-Objekt enthaltenen Zeilen- und Spaltendaten.

Die Methoden der ResultSet-Schnittstelle können in drei Kategorien unterteilt werden:

  • Navigational methods: Wird verwendet, um den Cursor zu bewegen.

  • Get methods: Dient zum Anzeigen der Daten in den Spalten der aktuellen Zeile, auf die der Cursor zeigt.

  • Update methods:Wird verwendet, um die Daten in den Spalten der aktuellen Zeile zu aktualisieren. Die Aktualisierungen können dann auch in der zugrunde liegenden Datenbank aktualisiert werden.

Der Cursor ist basierend auf den Eigenschaften des ResultSet beweglich. Diese Eigenschaften werden festgelegt, wenn die entsprechende Anweisung erstellt wird, die das ResultSet generiert.

JDBC bietet die folgenden Verbindungsmethoden zum Erstellen von Anweisungen mit dem gewünschten ResultSet:

  • createStatement(int RSType, int RSConcurrency);

  • prepareStatement(String SQL, int RSType, int RSConcurrency);

  • prepareCall(String sql, int RSType, int RSConcurrency);

Das erste Argument gibt den Typ eines ResultSet-Objekts an und das zweite Argument ist eine von zwei ResultSet-Konstanten, mit denen angegeben wird, ob eine Ergebnismenge schreibgeschützt oder aktualisierbar ist.

Art des ResultSet

Die möglichen RSType sind unten angegeben. Wenn Sie keinen ResultSet-Typ angeben, erhalten Sie automatisch den Typ TYPE_FORWARD_ONLY.

Art Beschreibung
ResultSet.TYPE_FORWARD_ONLY Der Cursor kann sich nur in der Ergebnismenge vorwärts bewegen.
ResultSet.TYPE_SCROLL_INSENSITIVE Der Cursor kann vorwärts und rückwärts scrollen, und die Ergebnismenge reagiert nicht auf Änderungen, die andere an der Datenbank vorgenommen haben und die nach der Erstellung der Ergebnismenge vorgenommen wurden.
ResultSet.TYPE_SCROLL_SENSITIVE. Der Cursor kann vorwärts und rückwärts scrollen, und die Ergebnismenge reagiert empfindlich auf Änderungen, die andere an der Datenbank vorgenommen haben, nachdem die Ergebnismenge erstellt wurde.

Parallelität von ResultSet

Die mögliche RSConcurrency sind unten angegeben. Wenn Sie keinen Parallelitätstyp angeben, erhalten Sie automatisch den Typ CONCUR_READ_ONLY.

Parallelität Beschreibung
ResultSet.CONCUR_READ_ONLY Erstellt eine schreibgeschützte Ergebnismenge. Dies ist die Standardeinstellung
ResultSet.CONCUR_UPDATABLE Erstellt eine aktualisierbare Ergebnismenge.

Alle unsere bisher geschriebenen Beispiele können wie folgt geschrieben werden: Dadurch wird ein Anweisungsobjekt initialisiert, um ein schreibgeschütztes ResultSet-Objekt nur für die Weiterleitung zu erstellen.

try {
   Statement stmt = conn.createStatement(
                           ResultSet.TYPE_FORWARD_ONLY,
                           ResultSet.CONCUR_READ_ONLY);
}
catch(Exception ex) {
   ....
}
finally {
   ....
}

Navigieren in einer Ergebnismenge

Es gibt verschiedene Methoden in der ResultSet-Oberfläche, bei denen der Cursor bewegt wird, darunter -

SN Methoden & Beschreibung
1 public void beforeFirst() throws SQLException

Bewegt den Cursor kurz vor der ersten Zeile.

2 public void afterLast() throws SQLException

Bewegt den Cursor direkt nach der letzten Zeile.

3 public boolean first() throws SQLException

Bewegt den Cursor in die erste Zeile.

4 public void last() throws SQLException

Bewegt den Cursor in die letzte Zeile.

5 public boolean absolute(int row) throws SQLException

Bewegt den Cursor in die angegebene Zeile.

6 public boolean relative(int row) throws SQLException

Bewegt den Cursor um die angegebene Anzahl von Zeilen vorwärts oder rückwärts, von wo aus er gerade zeigt.

7 public boolean previous() throws SQLException

Bewegt den Cursor zur vorherigen Zeile. Diese Methode gibt false zurück, wenn die vorherige Zeile nicht in der Ergebnismenge enthalten ist.

8 public boolean next() throws SQLException

Bewegt den Cursor in die nächste Zeile. Diese Methode gibt false zurück, wenn die Ergebnismenge keine Zeilen mehr enthält.

9 public int getRow() throws SQLException

Gibt die Zeilennummer zurück, auf die der Cursor zeigt.

10 public void moveToInsertRow() throws SQLException

Bewegt den Cursor auf eine spezielle Zeile in der Ergebnismenge, mit der eine neue Zeile in die Datenbank eingefügt werden kann. Die aktuelle Cursorposition wird gespeichert.

11 public void moveToCurrentRow() throws SQLException

Bewegt den Cursor zurück zur aktuellen Zeile, wenn sich der Cursor derzeit in der Einfügezeile befindet. Andernfalls führt diese Methode nichts aus

Lassen Sie uns zum besseren Verständnis Navigate - Beispielcode studieren .

Anzeigen einer Ergebnismenge

Die ResultSet-Schnittstelle enthält Dutzende von Methoden zum Abrufen der Daten der aktuellen Zeile.

Für jeden der möglichen Datentypen gibt es eine get-Methode, und jede get-Methode hat zwei Versionen -

  • Eine, die einen Spaltennamen enthält.

  • Eine, die einen Spaltenindex aufnimmt.

Wenn die Spalte, die Sie anzeigen möchten, beispielsweise ein int enthält, müssen Sie eine der Methoden getInt () von ResultSet - verwenden.

SN Methoden & Beschreibung
1 public int getInt(String columnName) throws SQLException

Gibt das int in der aktuellen Zeile in der Spalte mit dem Namen columnName zurück.

2 public int getInt(int columnIndex) throws SQLException

Gibt das int in der aktuellen Zeile im angegebenen Spaltenindex zurück. Der Spaltenindex beginnt bei 1, dh die erste Spalte einer Zeile ist 1, die zweite Spalte einer Zeile ist 2 usw.

In ähnlicher Weise gibt es in der ResultSet-Schnittstelle get-Methoden für jeden der acht primitiven Java-Typen sowie allgemeine Typen wie java.lang.String, java.lang.Object und java.net.URL.

Es gibt auch Methoden zum Abrufen der SQL-Datentypen java.sql.Date, java.sql.Time, java.sql.TimeStamp, java.sql.Clob und java.sql.Blob. Weitere Informationen zur Verwendung dieser SQL-Datentypen finden Sie in der Dokumentation.

Lassen Sie uns zum besseren Verständnis Viewing - Example Code studieren .

Aktualisieren einer Ergebnismenge

Die ResultSet-Schnittstelle enthält eine Sammlung von Aktualisierungsmethoden zum Aktualisieren der Daten einer Ergebnismenge.

Wie bei den get-Methoden gibt es für jeden Datentyp zwei Aktualisierungsmethoden:

  • Eine, die einen Spaltennamen enthält.

  • Eine, die einen Spaltenindex aufnimmt.

Um beispielsweise eine String-Spalte der aktuellen Zeile einer Ergebnismenge zu aktualisieren, verwenden Sie eine der folgenden updateString () -Methoden:

SN Methoden & Beschreibung
1 public void updateString(int columnIndex, String s) throws SQLException

Ändert den String in der angegebenen Spalte in den Wert von s.

2 public void updateString(String columnName, String s) throws SQLException

Ähnlich wie bei der vorherigen Methode, außer dass die Spalte durch ihren Namen anstelle ihres Index angegeben wird.

Das Paket java.sql enthält Aktualisierungsmethoden für die acht primitiven Datentypen sowie für die Datentypen String, Object, URL und SQL.

Durch das Aktualisieren einer Zeile in der Ergebnismenge werden die Spalten der aktuellen Zeile im ResultSet-Objekt geändert, jedoch nicht in der zugrunde liegenden Datenbank. Um Ihre Änderungen an der Zeile in der Datenbank zu aktualisieren, müssen Sie eine der folgenden Methoden aufrufen.

SN Methoden & Beschreibung
1 public void updateRow()

Aktualisiert die aktuelle Zeile, indem die entsprechende Zeile in der Datenbank aktualisiert wird.

2 public void deleteRow()

Löscht die aktuelle Zeile aus der Datenbank

3 public void refreshRow()

Aktualisiert die Daten in der Ergebnismenge, um die letzten Änderungen in der Datenbank widerzuspiegeln.

4 public void cancelRowUpdates()

Bricht alle in der aktuellen Zeile vorgenommenen Aktualisierungen ab.

5 public void insertRow()

Fügt eine Zeile in die Datenbank ein. Diese Methode kann nur aufgerufen werden, wenn der Cursor auf die Einfügezeile zeigt.

Lassen Sie uns zum besseren Verständnis den Code für die Aktualisierung - Beispiel studieren .