Einen ResultSet in Java zurückgeben
Der Zugriff auf eine Datenbanktabelle erfordert häufig das Abrufen eines Ergebnissatzes, der mehrere Datenzeilen enthält. Traditionell wurden diese Ergebnismengen zurückgegeben und anschließend iteriert, um einzelne Zeilen zu extrahieren. Bei diesem Ansatz gibt es jedoch potenzielle Probleme.
Das Problem der Schließbarkeit von Ergebnismengen
Eine der Herausforderungen bei der Verwaltung von Ergebnismengen ist ihre inhärente Schließbarkeit. Sobald eine Ergebnismenge geschlossen ist, werden auch die zugehörige Anweisung und Verbindung geschlossen, sodass für weitere Vorgänge nicht mehr darauf zugegriffen werden kann. Dies kann zum sogenannten „Vorgang nicht zulässig, nachdem ResultSet geschlossen wurde“-Fehler führen.
Eine Lösung: Zuordnung zu Sammlungen
Um diese Probleme zu vermeiden, ist es ratsam die Rückgabe roher Ergebnismengen in öffentlichen Methoden zu unterlassen. Erwägen Sie stattdessen, die Ergebnismenge einer Sammlung von JavaBeans zuzuordnen und stattdessen diese Sammlung zurückzugeben. Dadurch bleiben die Anweisung und die Verbindung offen, bis die Sammlung nicht mehr benötigt wird, wodurch ein vorzeitiges Schließen verhindert wird.
Hier ist ein Beispiel, wie dies implementiert werden könnte:
public List<Biler> list() throws SQLException { // Initialize connection, statement, and result set Connection connection = ... PreparedStatement statement = ... ResultSet resultSet = ... List<Biler> bilers = new ArrayList<>(); // Iterate over the result set and map rows to JavaBeans while (resultSet.next()) { Biler biler = new Biler(); // Set properties of the JavaBean from the result set ... bilers.add(biler); } return bilers; }
Im obigen Code wird die Die Methode list() gibt eine Liste von JavaBean-Objekten zurück, die jeweils eine Zeile in der Datenbanktabelle darstellen. Dieser Ansatz stellt sicher, dass die Verbindung und die Anweisung geöffnet bleiben, bis die zurückgegebene Sammlung nicht mehr benötigt wird, wodurch die Möglichkeit einer vorzeitigen Schließung ausgeschlossen wird.
Verwendung von Try-with-Resources
Mit Java 7 wurde die Try-with-Resources-Anweisung eingeführt, die die Verwaltung von Ressourcen vereinfacht, die geschlossen werden müssen. Im folgenden Codeausschnitt werden die Verbindung, die Anweisung und die Ergebnismenge am Ende des Try-Blocks automatisch geschlossen:
public List<Biler> list() throws SQLException { try ( Connection connection = ... PreparedStatement statement = ... ResultSet resultSet = ... ) { // Iterate over the result set and map rows to JavaBeans ... } return bilers; }
Durch den Einsatz dieser Techniken können Sie Ergebnismengen in Ihrem Java sicher und effizient verarbeiten Code, um sicherzustellen, dass Datenbankressourcen korrekt verwaltet werden und potenzielle Ausnahmen vermieden werden.
Das obige ist der detaillierte Inhalt vonWie kann ich ResultSets in Java sicher handhaben, um ein vorzeitiges Schließen zu vermeiden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!