Ok, also dies hier ist mal ein Teil der Klasse:
Aber wie gesagt, in Eclipse funktioniert das ja so. Das verstehe ich eben nicht. Die VM scheint da den Treiber ja zu finden. Also ich habe jetzt noch mal das ganze projekt neu angelegt, die Klassen erzeugt und den Code reinkopiert. Dann habe ich einfach nur die Derby.jar in das Verzeichnis geschoben und es geht.
Warum denn nicht ohne Eclipse?
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.sql.BatchUpdateException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.StringTokenizer;
/\*\*
\* Klasse zur Abfrage der Datenbank - Die Klasse Derby.java dient der Verbindung
\* zur Derby-Datenbank, der Trennung der Verbindung, sowie dem Abfragen,
\* Erzeugen und Löschen von Daten.
\*/
public class Derby {
int[] updateCounts = null;
public boolean PasswordUsername = false;
public int UserLevel = 0;
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* Datenbankverbindung etc. \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
/\*\*
\* Verbindung zur Datenbank
\*/
Connection connection;
/\*\*
\* JDBC-Treiber-Name - Muss im Klassenpfad sein.
\*/
static final String DRIVER = "org.apache.derby.jdbc.EmbeddedDriver";
/\*\*
\* Verbindungs-URL - Erstellt beim ersten Aufruf eine neue Datenbank.
\*/
//static final String URL = "jdbc:derby:c:/KnowHowDB;create=true";
static final String URL = "jdbc:derby:" + System.getProperty( "user.dir" ).replace('\\','/') + "/KnowHowDB;create=true";
/\*\*
\* Verbindung zur Datenbank herstellen.
\*/
public void connect() {
// Treiber laden
try {
Class.forName(DRIVER).newInstance();
} catch (Exception ex) {
System.out.println("Der JDBC-Treiber konnte nicht "
+ "geladen werden.");
System.exit(1);
}
// Verbindung herstellen
try {
connection = DriverManager.getConnection(URL);
} catch (SQLException ex) {
System.out.println("Die Verbindung zur Datenbank konnte "
+ "nicht hergestellt werden. "
+ "Die Fehlermeldung lautet: " + ex.getMessage());
System.exit(1);
}
}
/\*\*
\* Verbindung trennen
\*/
public void disconnect() {
try {
if (connection != null && !connection.isClosed()) {
connection.close();
connection = null;
}
} catch (SQLException ex) {
System.out.println("Die Verbindung zur Datenbank "
+ "konnte nicht geschlossen werden. "
+ "Die Fehlermeldung lautet: " + ex.getMessage());
System.exit(1);
}
}
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* SQL-Abfrage allgemein \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
//\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*
/\*\*
\* SQL-Statement an die Datenbank absetzen (Fehlerbehandlung, etc)
\*/
public void sqlStatement(String Statement) {
String message1 = "SQLException in sqlStatement. Die Fehlermeldung lautet: ";
String message2 = "BatchUpdateException in sqlStatement. Die Fehlermeldung lautet: ";
try {
Statement s = connection.createStatement();
s.addBatch(Statement);
updateCounts = s.executeBatch();
} catch (BatchUpdateException e) {
System.out.println(message2 + e.getMessage());
} catch (SQLException e) {
System.out.println(message1 + e.getMessage());
}
}
Also entpacken brauchst du das nicht.
Einfach die jar datein nehmen und in dein Projekt/lib
kopieren.
Den Ordner Lib vorher erstellen.
Dann importieren. mit import org.apache… und nochmal
versuchen.
Hoffe das ich überhaupt richtig liege mit meiner vermutung,
dass es so klappen soll.
poste doch mal bitte die klasse, in der du auf das Ding
zugreifst.
danke
gruß basti