java.sql Statement kann nicht geschlossen werden

Carcharoth

Bekanntes Mitglied
Guten Tag

Ich brüte jetzt schon eine ganze Weile über einen kleinen Fehler in meinem Code.
Wenn ich den Code so ausführe, bekomme ich eine Fehlermeldung
Java:
net.ucanaccess.jdbc.UcanaccessSQLException: UCAExc:::4.0.4 statement is closed
.

Kommentiere ich die Zeile 51 in der Methode executeSQL - statement.close() - aus, läuft es prima.
Für mich ist das nicht logisch denn ich brauche ja das Statement nicht mehr wenn das Resultat im ResultSet gespeichert ist.
Zusätzlich hatte ich vorher die gleiche Klasse mit HSQLDB anstatt mit UCANACCESS so am laufen, und da war es kein Problem.

Ich frage mich:
a) wieso das statement nicht geschlossen werden darf ?
b) was passiert wenn ich es einfach nicht schliesse? erledigt das der Garbage Collector?

Java:
import java.sql.*;

// <dependency>
//     <groupId>net.sf.ucanaccess</groupId>
//     <artifactId>ucanaccess</artifactId>
//     <version>4.0.4</version>
// </dependency>

public class Accdb {

    private Connection con;               
    private String path;               
    private String user;               
    private String password;           
    private String tableName;           

    // Konstruktor
    Accdb(String path, String user, String password, String tableName) {
        this.path = path;
        this.user = user;
        this.password = password;
        this.tableName = tableName;

        try{
            con = DriverManager.getConnection("jdbc:ucanaccess://" + path, user, password);
        }catch(SQLException se){
            se.printStackTrace();
        }
    }

    // Schliessen der Connection
    public void closeConnection() {
        try {
            con.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    // Ausführen des Query
    public ResultSet executeSQL(String sql) {
        Statement statement=null;
        ResultSet res=null;

        try {
            statement = con.createStatement(
                    ResultSet.TYPE_SCROLL_INSENSITIVE,
                    ResultSet.CONCUR_READ_ONLY);

            res = statement.executeQuery(sql);
            statement.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return res;
    }

    // Lesen aller Einträge der DB und Ausgabe über die Konsole
    public void readDB() {
        try {
            ResultSet res = executeSQL("SELECT * FROM " + tableName);

            if (res.next()) {
//                res.last();
//                System.out.println("Total rows is : " + res.getRow() + "\n");
//
//                res.beforeFirst();

                int columnCount = res.getMetaData().getColumnCount();
                int rowNumber=1;
                while (res.next()) {
                    System.out.print(rowNumber + ":  ");
                    for (int i = 1;i<=columnCount;i++ ) {
                        if (i!=columnCount) {
                            System.out.print(res.getString(i) + ", ");
                        } else System.out.print(res.getString(i));
                    }
                    System.out.println();
                    rowNumber++;
                }
            } else {
                System.out.println("No Data");
            }

            res.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) {
        Accdb accdb = new Accdb("H:\\Database.accdb", "","","Data");
        System.out.println("DB is open.");
        System.out.println("------------------------------------------------------------------------------------------------");

        accdb.readDB();

        accdb.closeConnection();
        System.out.println("------------------------------------------------------------------------------------------------");
        System.out.println("DB has been closed !");
    }
}
 
K

kneitzel

Gast
Also im Augenblick kann ich das noch nicht ganz nachvollziehen, dass in Zeile 51 die Exception kommt. Ich würde die Exception in readDB erwarten.

Das Statement solltest Du erst schließen, wenn auch das ResultSet verarbeitet ist. Das Statement zu schließen um dann das ResultSet zu verarbeiten, wird so nicht funktionieren.

Üblich ist:
a) try with resources - Es wird also nicht selbst close aufgerufen sondern das macht das try with resources für dich.
b) Innerhalb des try blocks erfolgt auch die Verarbeitung des ResultSets.

Wenn Du das anders machen möchtest, dann geht das natürlich auch. Dazu hat das Statement ein closeOnCompletion Aufruf.
Dann wird das Statement erst mit dem schließen des ResultSets geschlossen.

Aber:
Das close gehört dann generell in ein finally:

Also das Pattern für manuelles schließen ist immer sowas wie:

Java:
Statement statement;
try {
    statement = ....;
} finally {
    if (statement != null) statement.close();
}

Wobei ich da dann gerne eine Methode safeClose(Closable) hatte, die halt die Prüfung gemacht hat und Exceptions gefangen und ignoriert hat.
Aber: Es gibt das try with resources und das sollte man nutzen!
 

Carcharoth

Bekanntes Mitglied
Danke.

Das Statement solltest Du erst schließen, wenn auch das ResultSet verarbeitet ist. Das Statement zu schließen um dann das ResultSet zu verarbeiten, wird so nicht funktionieren.
Diese Erkenntnis hilft schon weiter.

Ich versuch mich mal ans Try with resources.
 
K

kneitzel

Gast
bedeutet die meldung nicht ganz simpel, dass das Statement an dem Punkt bereits geschlossen ist ??
Ja, genau. Und die Exception kommt vermutlich beim Zugriff auf das ResultSet. Das erfordert eine offenes Statement. Daher läuft es durch, wenn das Statement nicht geschlossen wird. Das Ergebnis wird in der Regel ausgewertet, ehe man das Statement schließt. (So kenne ich das eigentlich nur) Oder eben die Alternative: closeOnCompletion - dann wird es geschlossen, wenn das ResultSet geschlossen wird.
 

Carcharoth

Bekanntes Mitglied
Ich habe die Methode executeSQL wie folgt umgeschrieben (mit einem Try with Resources).
Ich musste leider im Catch das null zurückgeben, da Java sonst meckert, dass der return fehlt.

Java:
public ResultSet executeSQL(String sql) {
        try (ResultSet res = con.createStatement(
                    ResultSet.TYPE_SCROLL_INSENSITIVE,
                    ResultSet.CONCUR_READ_ONLY).executeQuery(sql)) {
            return res;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

Nachdem ich in der Methode readDB den obengenannten Code aufrufe
Java:
ResultSet res = executeSQL("SELECT * FROM " + tableName);

führt der erste Zugriff auf res.next() zu einem Fehler "invalid cursor state: identified cursor is not open".
 

fhoffmann

Top Contributor
Du solltest die Idee vergessen, ein ResultSet zurückzugeben.
Sobald das Statement geschlossen ist, kann das ResultSet nicht mehr benutzt werden.

Der Grund ist folgender:
Es ist denkbar, dass das ResultSet am Anfang noch nicht alle Zeilen enthält (sondern beispielsweise nur die ersten 50 Zeilen). Erst wenn du mit resultSet.next() weitere Zeilen abfragst, werden diese von der Datenbank geholt. Und das geht nur, wenn das Statement noch offen ist.

Wenn du dazu mehr wissen willst, suche einmal nach "Datenbank Cursor".
 

Carcharoth

Bekanntes Mitglied
OK das leuchtet mir ein mit deinem Beispiel.
Was ist aber dann die Alternative? gleich beim lesen des Resultsets die Daten in eine andere Datenstrutkur transferieren und diese zurückgeben?
 
K

kneitzel

Gast
Du solltest den Code nicht so strukturiewren - das ist das, was ich mit
nnerhalb des try blocks erfolgt auch die Verarbeitung des ResultSets.
meinte.

Also so ein typischer Aufbau wäre bei Dir einfach ein:

Java:
    public void readDB() {
        try (Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_READ_ONLY);
             ResultSet res = stmt.executeQuery(sql)) {
            
            while (res.next()) {
               // Zeile verarbeiten
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8
MiMa Java Doc mehrere Return Parameter Java Basics - Anfänger-Themen 11
Hzrfa Länge der längsten Kette java Java Basics - Anfänger-Themen 56

Ähnliche Java Themen

Neue Themen


Oben