JTable dynamisch mit Datenbankinhalten füllen

Stoj

Mitglied
Hallo zusammen,

folgendes bereitet mir kopfzerbrechen:

Versuche die JTable meiner View mit Inhalten aus einer Datenbank zu füllen. Habe mich schon umgesehen und kam zu folgenden Lsg.Ansatz

Teil des View:

Java:
//Tabelle einpflegen
		DefaultTableModel tableModel = ies.getPruefungen();
		tableStatistik = new JTable(tableModel);
		scrollPane.setViewportView(tableStatistik);

Steuerungsklasse:

public DefaultTableModel getPruefungen(){
		return de.executePruefungsuebersicht(con);
	}

Modelklasse:
public DefaultTableModel executePruefungsuebersicht(Connection con){
				
		String pruefungsuebersicht = "Select p.pnr as Pruefungsnr, p.pruefsemester as Semester,"
				+ " modul.mname as Modul, pruefungsordnung.stgname as Studiengang,"
				+ " pruefungsordnung.stgordnung as StgOrdnung"
				+ " From pruefung p, moduljepo , pruefungsordnung, modul"
				+ " where modul.MID = moduljepo.mid "
				+ " and pruefungsordnung.ponr = moduljepo.ponr"
				+ " and (p.ponr = moduljepo.ponr and p.mid = moduljepo.mid)";
		
		Statement stmt = null;
		ResultSet rs = null;
		DefaultTableModel tableModel = null;
		
		try{
			
			stmt = con.createStatement();
			rs = stmt.executeQuery(pruefungsuebersicht);
			String[] columnNames =  {"Pruefungsnummer", "Pruefsemester", "Modul", "Studiengang", "Pruefungsordnung"};
			tableModel = new DefaultTableModel(columnNames, 0);
			
			while(rs.next()){
	
				String[] rsRow = {rs.getString(1), rs.getString(2), rs.getString(3), rs.getString(4), rs.getString(5)};
				tableModel.addRow(rsRow);
				
			}
			rs.close();
			stmt.close();
			con.close();
		
			return tableModel;
			
		}catch (SQLException exc){
			System.out.println("SQLException: ");
			while(exc !=null){
				System.out.println("SQLState: "+exc.getSQLState());
				System.out.println("Message: "+exc.getMessage());
				System.out.println("SQLCode: "+exc.getErrorCode());
			}
			return null;
		}
Bei Ausführung erscheint keine View und die Fehlermeldung NullpointerException
 

Anhänge

  • View.txt
    1,7 KB · Aufrufe: 3
Zuletzt bearbeitet:

stg

Top Contributor
Wenn Fehlermeldungen erscheinen: Immer den gesamten Stacktrace posten, das erleichtert das Suchen des Fehlers immens. Andernfalls kann man oft nur raten...

Vorab was grundsätzliches:
Du solltest die Aufgaben in deinem Code klar voneinander trennen. Z.B. eine Methode, die nur die Daten aus der Datenbank abholt. Der Tabelle selbst ist es ja egal, wo die Daten herkommen. Der Methode, welche die Tabelle aufbaut, solltest du dann einfach nur die nötigen Daten übergeben (wo auch immer diese dann herkommen...)
 

Stoj

Mitglied
Hi,

das mit den Stacktrace werde ich zukünftig machen. Hier schonmal für meinen Problemfall

Exception in thread "main" java.lang.NullPointerException
at Anwendungsschicht.InterpretiereErgebnislisteSteuerung.getPruefungen(InterpretiereErgebnislisteSteuerung.java:23)
at Praesentationsschicht.InterpretiereErgebnisFormular.<init>(InterpretiereErgebnisFormular.java:165)
at Praesentationsschicht.Testklasse.main(Testklasse.java:15)

Nun zu den Klassen, wo der Fehler anfiel

Klasse: InterpretiereErgebnisListeSteuerung

Java:
public DefaultTableModel getPruefungen(){
		return de.executePruefungsuebersicht(con);
	}

Klasse: InterpretiereErgebnisFormular
Java:
//Tabelle einpflegen
		DefaultTableModel tableModel = ies.getPruefungen();
		tableStatistik = new JTable(tableModel);
		scrollPane.setViewportView(tableStatistik);

Klasse mit der Main: Testklasse
Java:
public static void main(String[] args) {
		
		DatabaseConnection dc = new DatabaseConnection();
		Connection con = dc.getDBCon();
		new InterpretiereErgebnisFormular (con);

Klasse, die aus SQL das ResultSet holt:

Java:
public DefaultTableModel executePruefungsuebersicht(Connection con){
				
		String pruefungsuebersicht = "Select p.pnr as Pruefungsnr, p.pruefsemester as Semester,"
				+ " modul.mname as Modul, pruefungsordnung.stgname as Studiengang,"
				+ " pruefungsordnung.stgordnung as StgOrdnung"
				+ " From pruefung p, moduljepo , pruefungsordnung, modul"
				+ " where modul.MID = moduljepo.mid "
				+ " and pruefungsordnung.ponr = moduljepo.ponr"
				+ " and (p.ponr = moduljepo.ponr and p.mid = moduljepo.mid)";
		
		Statement stmt = null;
		ResultSet rs = null;
		DefaultTableModel tableModel = null;
		
		try{
			
			stmt = con.createStatement();
			rs = stmt.executeQuery(pruefungsuebersicht);
			String[] columnNames =  {"Pruefungsnummer", "Pruefsemester", "Modul", "Studiengang", "Pruefungsordnung"};
			tableModel = new DefaultTableModel(columnNames, 0);
			
			while(rs.next()){
	
				String[] rsRow = {rs.getString(1), rs.getString(2), rs.getString(3), rs.getString(4), rs.getString(5)};
				tableModel.addRow(rsRow);
				
			}
			rs.close();
			stmt.close();
			con.close();
		
			return tableModel;
			
		}catch (SQLException exc){
			System.out.println("SQLException: ");
			while(exc !=null){
				System.out.println("SQLState: "+exc.getSQLState());
				System.out.println("Message: "+exc.getMessage());
				System.out.println("SQLCode: "+exc.getErrorCode());
			}
			return null;
		}

Danke erstmal für deine Antwort. Aber ich weiß nicht, wie mir dein abgebildeter Code weiterhelfen kann.

Danke im Voraus.

mfg Stoj
 
Zuletzt bearbeitet:

stg

Top Contributor
Offenbar ist de gleich null

Was das genau ist und warum es nicht initialisert ist, kann man hier aber nicht sehen.
 
Zuletzt bearbeitet:

pitsoft21

Mitglied
Java:
private class MyTablemodel extends DefaultTablemodel {
	ArrayList data = null;

	public MyTablemodel(ArrayList _data) {
		this.data = _data;
		String[] columnNames = {
			"Pruefungsnummer", "Pruefsemester", "Modul", "Studiengang", "Pruefungsordnung"
		};
		this.setColumnCount(columnNames.length();
		this.setRowCount(data.size());
		this.setColumnIdentifiers(columnNames);
		}

		public Object getValueAt(int row, int columns) {
			ArrayList row = (ArrayList) data.get(row);
			return row.get(column);
		}
	}
}

Die ArrayList data wird mit einer ArrayList pro Row gefüllt. (in der while (rs.next) Schleife
und zurückgegeben.

So mache ich ein Tablemodel: table.setModel( new MyModel(data));.
 
Zuletzt bearbeitet von einem Moderator:
Ähnliche Java Themen
  Titel Forum Antworten Datum
G JTable dynamisch erzeugen. Java Basics - Anfänger-Themen 2
richis-fragen JTable den angezeigten WERT nicht den Wert aus dem Model ausgeben. Java Basics - Anfänger-Themen 3
richis-fragen JTable Header ausgeblendete (width = 0) nicht per mouseDragged aufziehen. Java Basics - Anfänger-Themen 9
richis-fragen JTable sowohl Spaltennamen wie auch Spaltenbeschriftungen Java Basics - Anfänger-Themen 7
richis-fragen JTable effektiv angezeigter Text ausgeben nicht Inhalt vom Model Java Basics - Anfänger-Themen 9
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
Mady Daten von JList & Combobox in JTable adden Java Basics - Anfänger-Themen 2
W Liste mit Listen in JTable darstellen Java Basics - Anfänger-Themen 1
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
E JTable einzelne Zelle färben Java Basics - Anfänger-Themen 2
thobren jtable arraylist Java Basics - Anfänger-Themen 12
thobren JTable Icon Java Basics - Anfänger-Themen 1
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
H Kapselung JProgressBar in JTable, aber getValueAt() greift nicht Java Basics - Anfänger-Themen 7
G JTable, Zeile auswählen und Ergebnis an Schaltfläche übergeben Java Basics - Anfänger-Themen 4
J Jtable Eingabe nach Klick ausserhalb der Tabelle übernehmen Java Basics - Anfänger-Themen 6
J JTable Spalteninhalt löschen Java Basics - Anfänger-Themen 1
J JTable Titel wird nicht angezeigt Java Basics - Anfänger-Themen 6
B jTable Spalte summieren Java Basics - Anfänger-Themen 7
N JTable auslesen Java Basics - Anfänger-Themen 6
O JTable in Excel mit Farben Java Basics - Anfänger-Themen 8
O Kommentar auf JTable Zelle Java Basics - Anfänger-Themen 2
M Jtable Reenderer Java Basics - Anfänger-Themen 0
O Popoup Menü im JTable richtig anzeigen Java Basics - Anfänger-Themen 6
M Jtable änderung updaten Java Basics - Anfänger-Themen 2
O JTable Suchfunktion Java Basics - Anfänger-Themen 2
M jTable bekommt null Java Basics - Anfänger-Themen 1
M JTable an andere Klasse übergeben Java Basics - Anfänger-Themen 2
M Datenbank in jTable Laden Java Basics - Anfänger-Themen 49
M Klasse in JTable einfügen Java Basics - Anfänger-Themen 7
S JTable Java Basics - Anfänger-Themen 16
S JTable mit Daten füllen Java Basics - Anfänger-Themen 7
L JTable Tagebuch Spaltenhöhe verändern Java Basics - Anfänger-Themen 3
S JTable - Filter an anderen Colums Java Basics - Anfänger-Themen 2
R JTable Suchfunktion mit SQL Daten Java Basics - Anfänger-Themen 2
C JTable update mit MySQL Datenbank Java Basics - Anfänger-Themen 1
C Best Practice JTable in MVC Pattern Java Basics - Anfänger-Themen 7
J Daten einer Textdatei in ein JTable importieren. Java Basics - Anfänger-Themen 3
A zykl. Aktualisierne JTable Java Basics - Anfänger-Themen 9
C Endlosschleife bei füllen von Daten im JTable Java Basics - Anfänger-Themen 5
C Werte aus JTable auslesen Java Basics - Anfänger-Themen 4
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
V JTable welcher Listener ? Java Basics - Anfänger-Themen 7
D Falsche Zeile wird in JTable gelöscht Java Basics - Anfänger-Themen 6
D MySQL Abfrage in JTable speichern Java Basics - Anfänger-Themen 43
D JTable Zeile wird nicht in MySQL gelöscht Java Basics - Anfänger-Themen 16
D JTable Zeilen löschen Java Basics - Anfänger-Themen 5
C Klassen JTable wird ohne Header aufgebaut Java Basics - Anfänger-Themen 6
K (JTable) Text einer Zelle auf der linken Seite kürzel Java Basics - Anfänger-Themen 2
B Kniffel JTable Java Basics - Anfänger-Themen 5
N JTable flackert Java Basics - Anfänger-Themen 8
T JTable Daten aus txt datei Java Basics - Anfänger-Themen 3
J ArrayList wird in JTable falsch angezeigt Java Basics - Anfänger-Themen 0
J Eintragen von Personen in JTable Java Basics - Anfänger-Themen 4
X JTable mit grünen und roten Punkten Java Basics - Anfänger-Themen 2
LexeB4F DEL --> JTable Zelleninhalt Java Basics - Anfänger-Themen 3
R JTable Auslesen Java Basics - Anfänger-Themen 1
Crazynet jTable erste Zeile mit deffinierten Werten Java Basics - Anfänger-Themen 0
K Collections Sortieren nach zweiter Spalte in JTable Java Basics - Anfänger-Themen 18
J JTable Wert gleich überschreiben Java Basics - Anfänger-Themen 6
S Zeile entfernen aus JTable Java Basics - Anfänger-Themen 15
S JTable clonen Java Basics - Anfänger-Themen 5
H Best Practice PDF JTable Java Basics - Anfänger-Themen 4
S In JTable Zeile selektieren mit Mausklick Java Basics - Anfänger-Themen 16
D JTable Probleme beim Sortieren von Zahlen. Java Basics - Anfänger-Themen 6
M JTable mit XML datei befüllen Java Basics - Anfänger-Themen 1
F Zeile bei JTable hinzufügen Java Basics - Anfänger-Themen 6
K JTable Bild einfügen Java Basics - Anfänger-Themen 1
M [JTable] getValue throws ArrayOutOfBoundException Java Basics - Anfänger-Themen 1
B JTable - Highlighter ??? Java Basics - Anfänger-Themen 3
S JTable LinkedList <Objekt> befüllen Java Basics - Anfänger-Themen 1
W JTable mit einem JButton-Array füllen Java Basics - Anfänger-Themen 4
O JScrollPane zu gross für JTable Java Basics - Anfänger-Themen 2
L JTable Row selected -> fireTableDataChange do nothing. Java Basics - Anfänger-Themen 3
E JTable + TableModel updaten? Java Basics - Anfänger-Themen 1
O java.lang.IndexOutOfBoundsException JTable autoSort Java Basics - Anfänger-Themen 5
F JTable adding Row Java Basics - Anfänger-Themen 5
P jTable getColumnClass, mit unterschiedlichen Klassen in einer Column? Java Basics - Anfänger-Themen 5
M Eingabe in JTable bei Eingabe korrigieren Java Basics - Anfänger-Themen 2
Z jtable problem (das tausendste??) Java Basics - Anfänger-Themen 12
J JTable Java Basics - Anfänger-Themen 7
T JTable Java Basics - Anfänger-Themen 2
T JTable einzelne Zeilen löschen Java Basics - Anfänger-Themen 3
S Farbe eine Zeile in JTable ändern, wenn JButton geklickt wurd Java Basics - Anfänger-Themen 4
Uzi21 jTable / Inhalt speichern Java Basics - Anfänger-Themen 2
M Problem mit JTable und Model Java Basics - Anfänger-Themen 3
F Methoden JTable + 2 For-Schleifen Java Basics - Anfänger-Themen 4
C jtextfield und jtable Java Basics - Anfänger-Themen 34
X JTable mit Inhalten aus JTextField o.ä. füllen Java Basics - Anfänger-Themen 4
G JTable: SelectionListener Problem Java Basics - Anfänger-Themen 2
G JTable: Werte in Tabelle direkt ansprechen Java Basics - Anfänger-Themen 3
S Icons in JTable per ResultSet Java Basics - Anfänger-Themen 5
G Spalte in JTable unsichtbar machen, Zugriff auf Daten ermöglichen Java Basics - Anfänger-Themen 2
M Zelle von JTable mit Rahmen versehen Java Basics - Anfänger-Themen 4
G JTable: Inhalt einer selektierten Zeile speichern Java Basics - Anfänger-Themen 2
G JTable: mehrzeilige Zellen erstellen Java Basics - Anfänger-Themen 2
W Problem JTable Java Basics - Anfänger-Themen 5
M JTable wird nicht aktualisiert Java Basics - Anfänger-Themen 4
D jProgressBar soll bei 100% sein wenn sql Abfrage inkl. jTable schreiben fertig ist... Java Basics - Anfänger-Themen 5
S Warum wird JTable nicht angezeigt Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben