Hi,
ich habe ein Umsetzungsproblem beim Füllen von Tabellen. Manche meiner Tabellen besitzen mehr als 1.000.000 Datensäte (Testdaten für worst case) und es dauert bei meiner H2 unter Umständen schon ein paar Sekündchen bis ich die Daten in der Tabelle habe, so dass es fast schon so aussieht, als ob das Programm hängen würde.
Ich möchte also ein Fortschrittsbalken oder wenigstens ein Lade-Gif oder so anzeigen damit "sich was bewegt".
Ich benutze folgende Methode mit Eingabeparameter für die Query und die Namen für die einzelnen Columns.
Mit Hilfe dieser Methode setze ich einfach eines neues TableModel mit neu abgefragten Daten:
Ist es möglich, dass ich diese Methode auf einfachem Wege ändere, dass sie mir einen Fortschrittsbalken oder einfach nur ein Gif anzeigt, dass sich entsprechend bewegt?
Habe schon die Tuts zu "ProgressBars, Algorithmen und Multithreading" gelesen, was mir aber ziemlich "umfangreich" vorgekommen ist. Gibt es da keine einfachere Methode? Zumal ich bei der Umsetzung des Codebeispiels auch meine Probleme hatte. Welche Technik ist da am einfachsten nutzbar und nicht so codeumfassend? Ist Swingworker das richtige für mich oder liege ich das eher falsch?
Ein weiteres Problem habe ich auch wenn ich unterschiedliche TableModel habe und nur diese obige Funktion nutzen möchte. Wie halte ich den Rückgabetyp den variabel? Das wird wohl ein Grundlagendefezit bei mir sein...
Also, dass ich eine bestimmte von TableModel abgeleitete Klasse mit übergeben kann und diese dann entsprechend zurückgegeben wird. Ist das möglich? Denn zur Zeit nutze ich für jedes unterschiedliche TableModel ne eigene Methode wie oben. Das kann ja auch nicht richtig sein
Ich danke schon mal für eure Anregungen. Vorallem zum/r Fortschrittsbalken/-anzeige.
ich habe ein Umsetzungsproblem beim Füllen von Tabellen. Manche meiner Tabellen besitzen mehr als 1.000.000 Datensäte (Testdaten für worst case) und es dauert bei meiner H2 unter Umständen schon ein paar Sekündchen bis ich die Daten in der Tabelle habe, so dass es fast schon so aussieht, als ob das Programm hängen würde.
Ich möchte also ein Fortschrittsbalken oder wenigstens ein Lade-Gif oder so anzeigen damit "sich was bewegt".
Ich benutze folgende Methode mit Eingabeparameter für die Query und die Namen für die einzelnen Columns.
Mit Hilfe dieser Methode setze ich einfach eines neues TableModel mit neu abgefragten Daten:
Code:
public static DefaultTableModel newModel(String query,String[] columnNames){
DefaultTableModel aModel = new DefaultTableModel();
Connection con;
try {
con = getConnection();
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery(query);
// TableModel definition
aModel.setColumnIdentifiers(columnNames);
// Loop through the ResultSet and transfer in the Model
final java.sql.ResultSetMetaData rsmd = rs.getMetaData();
int colNo = rsmd.getColumnCount();
while(rs.next()){
Object[] objects = new Object[colNo];
for(int i=0;i<colNo;i++){
objects[i]=rs.getObject(i+1);
}
aModel.addRow(objects);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return aModel;
}
Ist es möglich, dass ich diese Methode auf einfachem Wege ändere, dass sie mir einen Fortschrittsbalken oder einfach nur ein Gif anzeigt, dass sich entsprechend bewegt?
Habe schon die Tuts zu "ProgressBars, Algorithmen und Multithreading" gelesen, was mir aber ziemlich "umfangreich" vorgekommen ist. Gibt es da keine einfachere Methode? Zumal ich bei der Umsetzung des Codebeispiels auch meine Probleme hatte. Welche Technik ist da am einfachsten nutzbar und nicht so codeumfassend? Ist Swingworker das richtige für mich oder liege ich das eher falsch?
Ein weiteres Problem habe ich auch wenn ich unterschiedliche TableModel habe und nur diese obige Funktion nutzen möchte. Wie halte ich den Rückgabetyp den variabel? Das wird wohl ein Grundlagendefezit bei mir sein...
Also, dass ich eine bestimmte von TableModel abgeleitete Klasse mit übergeben kann und diese dann entsprechend zurückgegeben wird. Ist das möglich? Denn zur Zeit nutze ich für jedes unterschiedliche TableModel ne eigene Methode wie oben. Das kann ja auch nicht richtig sein
Ich danke schon mal für eure Anregungen. Vorallem zum/r Fortschrittsbalken/-anzeige.