Jtable erneut befüllen

quidnovi

Mitglied
Hi folks :)

Ich befrage eine eingebettete H2 - Datenbank nach allen Datensätzen in einer Tabelle
und lasse diese in einem DefaultTableModel ausgeben.
Hierzu rufe ich im Konstruktor auf:
Java:
showDb();
Der Quelltext von diesem Aufruf folgt weiter unten.


Nun erscheinen alle Datensätze in der dafür vorbereiteten Tabelle.
Wenn man nun auf eine Tabellenzeile klickt, dann erscheint der komplette Datensatz aufgesplittet in den dazugeörenden txtFields, basierend auf einer ID.
Hier kann man dann diesen Datensatz editieren und wiederum in der DB abspeichern.

Das alles funktioniert einwandfrei - nun zum Problem:

Nach dem try-catch - Block lösche ich die Spalten und Zeilen der Tabelle:
Java:
btnEintragAendern.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				try {
					
					Statement stmt = DBData.connection.createStatement();
					String updateDBTable;
					String where;
					updateDBTable = "UPDATE KOMMISSIONEN SET ";
					where = " WHERE ID = " + txtFldId.getText();
					stmt.executeUpdate(updateDBTable + "kommnr = '"
							+ txtFldKommNr.getText() + "'" + ", "
							+ "kommname = '" + txtFldKommName.getText() + "'"
							+ ", " + "strasse = '" + txtFldStrasse.getText()
							+ "'" + ", " + "hausnr = '"
							+ txtFldHausNr.getText() + "'" + ", " + "plz = '"
							+ txtFldPlz.getText() + "'" + ", " + "gemeinde = '"
							+ txtFldGemeinde.getText() + "'" + ", "
							+ "telnr = '" + txtFldTelNr.getText() + "'" + ", "
							+ "bemerkung1 = '" + txtFldBem1.getText() + "'"
							+ ", " + "bemerkung2 = '" + txtFldBem2.getText()
							+ "'" + where);
					JOptionPane.showMessageDialog(null,
							"btnEintragAendern/showDb() - Eintrag gespeichert");
				} catch (Exception e1) {
					JOptionPane.showMessageDialog(null, e1);
				}
				
				// Jetzt werden alle zeilen in der table geloescht				
				((DefaultTableModel)table.getModel()).setRowCount(0);
				((DefaultTableModel)table.getModel()).setColumnCount(0);
				
				// Nun sollte die geaenderte Tabelle "Kommissionen" die urspruengliche 
				// durch "showDb(); ersetzt werden
				try{
					showDb();
					JOptionPane.showMessageDialog(null, "ist jetzt neu geladen");
				}catch(Exception nixGeladen){
					nixGeladen.printStackTrace();
				}
			}
		});

Das Löschen funktioniert ja, nur wird die Tabelle durch showDb(); nicht mit den gerade abgefragten Daten befüllt.
Zur Kontrolle lasse ich diese Datensätze mit Erfolg auf der Konsole anzeigen.

Nun showDb();
Java:
public void showDb() {

		// DB - Tabelle Kommissionen Tabellenbezeichnung und Daten auslesen
		Vector<String> columnNames = new Vector<String>();
		Vector<Vector<Object>> data = new Vector<Vector<Object>>();

		new Vector<Object>();
		try {
			String sql = "SELECT * FROM KOMMISSIONEN";
			Statement stmt = DBData.connection.createStatement();
			ResultSet rs = stmt.executeQuery(sql);
			ResultSetMetaData rsmd = rs.getMetaData();
			int columns = rsmd.getColumnCount();
			for (int i = 1; i <= columns; i++) {
				columnNames.addElement(rsmd.getColumnName(i));
			}

			while (rs.next()) {
				Vector<Object> row = new Vector<Object>(columns);
				for (int i = 1; i <= columns; i++) {
					// row.addElement(rs.getObject(i)); // Original
					row.addElement(rs.getString("ID"));
					row.addElement(rs.getString("DATUM"));
					row.addElement(rs.getString("KOMMNR"));
					row.addElement(rs.getString("KOMMNAME"));
					row.addElement(rs.getString("STRASSE"));
					row.addElement(rs.getString("HAUSNR"));
					row.addElement(rs.getString("PLZ"));
					row.addElement(rs.getString("GEMEINDE"));
					row.addElement(rs.getString("TELNR"));
					row.addElement(rs.getString("BEMERKUNG1"));
					row.addElement(rs.getString("BEMERKUNG2"));
				}
				data.addElement(row);
			}
			rs.close();
			stmt.close();
		} catch (Exception e) {
			System.out.println(e);
		}

		// ----------------------------------------------------------------------

		// Auf der Konsole zur Kontrolle
		System.out.println("Methode: showDb - " + data + "\n");

		// ----------------------------------------------------------------------
		
		

		// DB - Ergebnisse in DefaultTableModel fuellen
		tabModel = new DefaultTableModel(data, columnNames);
		table = new JTable(tabModel);
		JScrollPane scrollPane = new JScrollPane(table);
...
Ich denke, dass ich nicht mal einen großen Wurm im Code habe - hoffe ich mal :oops:
Trotzdem komme ich nicht weiter, weshalb ich mich um Eure Hilfe bemühen will.

Werft doch mal bitte einen Blick darauf, ich hoffe, dass Ihr mir helfen könnt.

Danke im Voraus schonmal fürs lesen :)

Damit ich mich besser verständlich machen kann, habe ich einen Screenshot beigefügt.
 

Anhänge

  • AlleKommissionen.png
    AlleKommissionen.png
    102,9 KB · Aufrufe: 33

bERt0r

Top Contributor
Java:
 // DB - Ergebnisse in DefaultTableModel fuellen
        tabModel = new DefaultTableModel(data, columnNames);
        table = new JTable(tabModel);
        JScrollPane scrollPane = new JScrollPane(table);
Was du da machst ist nicht "DB - Ergebnisse in DefaultTableModel fuellen" sondern einen neuen JTable, samt Model und Scrollpane neu zu erstellen. Du hast doch nur einen Table. Dem kannst du problemlos mit setModel dein neues Model geben und er wird aktualisiert.
 

quidnovi

Mitglied
Hi bERt0r :)

danke für Deine Antwort...

Ja...das Ganze verstehe ich das jetzt leider nicht.
Wenn ich immer wieder einen neuen Table mit den aktuellen DB - Daten erzeuge,
wieso bleibt dann der "alte"?

[Edit]
Ist aber schonmal ein Ansatz...werd's probieren, werden sehen...
Auf all Fälle ein Danke für Deinen Input :)
[/Edit]
 
Zuletzt bearbeitet:

quidnovi

Mitglied
Hi Ihrs :)

geschafft! :D

War eigentlich gar nicht so schwer.
Da ich in meinem Code eine chaotisches Durcheinander hatte, haben sich einige Dinge drin "gebissen"
und somit nicht funktioniert.

Zusammenfassend:
Verwende ein DefaultTableModel, welches sich im Konstruktor befindet.
Dann einige Methoden und das Ganze läuft einwandfrei.

Zum Aktualisieren der Daten verwende ich "fireTableDataChanged();",
was mich schon ein wenig wundert, dachte ich doch, dass dies nur beim AbstractTableModel funktioniert.
Nunja...werde mich da noch genauer hineinlesen müssen.

Auf alle Fälle möchte ich mich bei den Lesern und vor allem den Hilfsbereiten sehr bedanken,
haben diese mich doch auf den richtigen Weg gebracht :)

Obwohl der Quellcode noch verbesserungswürdig ist (vor allem ist dieser noch sehr umfangreich),
möchte ich diesen doch hier posten, vielleicht hilft's ja jemanden in irgendeiner Weise.

Also solong derweil und vielen Dank nochmal :)

Hier der "ellenlange" ;) Code:
Java:
import java.awt.Color;
import java.awt.FlowLayout;
import java.awt.Font;
import java.awt.GridBagLayout;
import java.awt.Rectangle;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Vector;

import javax.swing.JButton;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.JTextField;
import javax.swing.table.DefaultTableModel;
import javax.swing.table.TableRowSorter;

import at.p4glass.db.DBConnect;
import at.p4glass.db.DBData;
import at.p4glass.design.DesignLabel;
import at.p4glass.design.GridBagHelp;

public class KommList extends JPanel{
	
	// serialVersionUID
	private static final long serialVersionUID = 3136098036201838809L;
	
	//-------------------------------------------------------------------------
	
	// Benoetigte Voraussetzungen für die Darstellung der Daten
	private JTable table;
	private DefaultTableModel tabModel;
	private TableRowSorter<DefaultTableModel> sorter;
	
	// Benoetigte Voraussetzungen für die Datenbank
	Connection connection = null;
	ResultSet rs = null;
	PreparedStatement stmt = null;

	//------------------------------------------------------------------------
	
	// Labels anlegen
	private JLabel lblAlleKommissionen; // Ueberschrift
	private JLabel lblHeadline; // Ueberschrift
	private JLabel lblId;
	private JLabel lblDatum;
	private JLabel lblKommissionsnummer;
	private JLabel lblKommName;
	private JLabel lblStrasse;
	private JLabel lblHausnummer;
	private JLabel lblPlz;
	private JLabel lblGemeinde;
	private JLabel lblTelnr;
	private JLabel lblBemerkung1;
	private JLabel lblBemerkung2;
	
	// txtFields anlegen
	private JTextField txtFldId;
	private JTextField txtFldDatum;
	private JTextField txtFldKommNr;
	private JTextField txtFldKommName;
	private JTextField txtFldStrasse;
	private JTextField txtFldHausNr;
	private JTextField txtFldPlz;
	private JTextField txtFldGemeinde;
	private JTextField txtFldTelNr;
	private JTextField txtFldBem1;
	private JTextField txtFldBem2;
	
	// Buttons anlegen
	private JButton btnReset;
	private JButton btnEintragAendern;
	private JButton btnEintragLoeschen;
	private JButton btnRefresh;
	private JButton btnSuchen;
	
	//======================================================================

	// Konstruktor
	public KommList(ActionListener listener) {
		setFont(new Font("Century Gothic", Font.PLAIN, 12));
		setForeground(Color.WHITE);
		this.setOpaque(false);

		GridBagLayout gbl = new GridBagLayout();
		// Größenänderung bei resize der einzelnen Spalten
		// 0 = bleibt gleich
		// 1.0 = wächst
		gbl.columnWeights = new double[] { 1.0, 1.0, 1.0, 1.0, 1.0 };
		// Spaltenbreite
		gbl.columnWidths = new int[] { 50, 0, 0, 0, 50 };

		// Größenänderung bei resize der einzelnen Zeilen
		// 0 = bleibt gleich
		// 1.0 = wächst
		gbl.rowWeights = new double[] { 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0,
				0.0, 0.0, 0.0, 0.0, 0.0 };
		// Zeilenhöhe
		gbl.rowHeights = new int[] { 20, 0, 20, 20, 20, 20, 20, 20, 20, 20, 20,
				0, 0 };
		setLayout(gbl);

		// ------------------------------------------------------------------------

		// Labels erstellen
		lblAlleKommissionen = new JLabel(); // Ueberschrift
		lblHeadline = new JLabel(); // Ueberschrift
		lblId = new DesignLabel("ID", 14);
		lblDatum = new DesignLabel("Datum", 14);
		lblKommissionsnummer = new DesignLabel("KommNr", 14);
		lblKommName = new DesignLabel("KommName", 14);
		lblStrasse = new DesignLabel("Strasse", 14);
		lblHausnummer = new DesignLabel("Hausnummer", 14);
		lblPlz = new DesignLabel("PLZ", 14);
		lblGemeinde = new DesignLabel("Gemeinde", 14);
		lblTelnr = new DesignLabel("TelNr", 14);
		lblBemerkung1 = new DesignLabel("Bemerkung 1", 14);
		lblBemerkung2 = new DesignLabel("Bemerkung2", 14);
		txtFldId = new JTextField();
		txtFldDatum = new JTextField();
		txtFldKommNr = new JTextField();
		txtFldKommName = new JTextField();
		txtFldStrasse = new JTextField();
		txtFldHausNr = new JTextField();
		txtFldPlz = new JTextField();
		txtFldGemeinde = new JTextField();
		txtFldTelNr = new JTextField();
		txtFldBem1 = new JTextField();
		txtFldBem2 = new JTextField();

		// ----------------------------------------------------------------------

		// Textfields disabled
		txtFldId.setEditable(false);
		txtFldDatum.setEditable(false);

		// ----------------------------------------------------------------------

		// Design Headline
		lblAlleKommissionen.setText("Alle Kommissionen");
		lblAlleKommissionen.setFont(new Font("Century Gothic", Font.BOLD, 15));
		lblAlleKommissionen.setForeground(Color.WHITE);

		lblHeadline
				.setText("<html><center>Hier k\u00F6nnen Sie jede einzelne Kommission \u00E4ndern oder l\u00F6schen</center></html>");
		lblHeadline.setFont(new Font("Century Gothic", Font.BOLD, 15));
		lblHeadline.setForeground(Color.WHITE);

		// ---------------------------------------------------------------------
		
		// Buttons

		// Suchmodus
		btnSuchen = new JButton("Kommissionen Suchen");
		btnSuchen.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				searchButton();
			}
		});

		// Datensatz in DB aendern
		btnEintragAendern = new JButton("Eintrag \u00E4ndern");
		btnEintragAendern.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				datensatzAendern();
			}
		});

		// Datensatz aus DB loeschen
		btnEintragLoeschen = new JButton("Eintrag l\u00F6schen");
		btnEintragLoeschen.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				datensatzLoeschen();
			}
		});

		// Datensaetze aus DB holen
		btnRefresh = new JButton("Tabelle aktualisieren");
		btnRefresh.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				callData();
			}
		});

		// Datensaetze erneut aus DB holen
		btnReset = new JButton("Suche zur\u00FCcksetzen");
		btnReset.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				reset();
			}
		});
		
		//-------------------------------------------------------------------------------				

		// GBC Labels
		this.add(lblAlleKommissionen,new GridBagHelp(1, 1, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblHeadline,new GridBagHelp(2, 1, 2, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblId,new GridBagHelp(0, 4, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblDatum,new GridBagHelp(2, 4, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblKommissionsnummer, new GridBagHelp(0, 5, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblKommName,new GridBagHelp(2, 5, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblStrasse,new GridBagHelp(0, 6, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblHausnummer, new GridBagHelp(2, 6, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblPlz,new GridBagHelp(0, 7, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblGemeinde,new GridBagHelp(2, 7, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblTelnr,new GridBagHelp(0, 8, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblBemerkung1, new GridBagHelp(2, 8, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(lblBemerkung2, new GridBagHelp(2, 9, 1, 1).anchorRight().bounds(0, 0, 5, 5, 0, 0).done());
		
		//--------------------------------------------------------------------------------
		
		// GBC txtFields
		this.add(txtFldId,new GridBagHelp(1, 4, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldDatum,new GridBagHelp(3, 4, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldKommNr,new GridBagHelp(1, 5, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldKommName,new GridBagHelp(3, 5, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldStrasse,new GridBagHelp(1, 6, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldHausNr,new GridBagHelp(3, 6, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldPlz,new GridBagHelp(1, 7, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldGemeinde,new GridBagHelp(3, 7, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldTelNr,new GridBagHelp(1, 8, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldBem1,new GridBagHelp(3, 8, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		this.add(txtFldBem2,new GridBagHelp(3, 9, 1, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());

		// --------------------------------------------------------------------------

		// GBC Buttons
		this.add(btnSuchen, new GridBagHelp(1, 3, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(btnEintragAendern,new GridBagHelp(1, 10, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(btnEintragLoeschen,new GridBagHelp(3, 10, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(btnRefresh,new GridBagHelp(2, 10, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		this.add(btnReset,new GridBagHelp(3, 3, 1, 1).bounds(0, 0, 5, 5, 0, 0).done());
		
		// --------------------------------------------------------------------------

		// JTextfields setColumns
		// Sichtbare Breite des Textfeldes
		// hier 10, also passen 10 m's hinein
		// m = Richtbuchstabe
		// wenn mehr Buchstaben eingegeben werden, verbreitert sich das txtFeld
		// nicht
		txtFldId.setColumns(10);
		txtFldDatum.setColumns(10);
		txtFldKommNr.setColumns(10);
		txtFldKommName.setColumns(10);
		txtFldStrasse.setColumns(10);
		txtFldHausNr.setColumns(10);
		txtFldPlz.setColumns(10);
		txtFldGemeinde.setColumns(10);
		txtFldTelNr.setColumns(10);
		txtFldBem1.setColumns(10);
		txtFldBem2.setColumns(10);	
		

		/*********************************************************************************/

		// DefaultTableModel
		tabModel = new DefaultTableModel() {

			// serialVersionUID
			private static final long serialVersionUID = -8189518063922844923L;

			// Zellen sperren
			public boolean isCellEditable(int row, int column) {
				return false;
			}
		};
		
		// Spaltennamen hinzufuegen
		tabModel.setColumnIdentifiers(COLUMN_IDENTIFIERS);
		
		// Model zu Table hinzufuegen
		table = new JTable(tabModel);
		table.setFont(new Font("Century Gothic", Font.PLAIN, 12));
		table.setEnabled(true);
		table.setAutoCreateRowSorter(true);
		table.setFillsViewportHeight(true);
		table.setOpaque(false);
		
		
		// Scrollpane erzeugen und table integrieren
		JScrollPane scrollPane = new JScrollPane(table);
		scrollPane.setOpaque(false);
		
		// GBC ScrollPane
		this.add(scrollPane,new GridBagHelp(0, 12, 5, 1).hfill().bounds(0, 0, 5, 5, 0, 0).done());
		
		// Datensaetze aufrufen
		callData();
		
	}

// =================================================================================================
	
	// Vector fuer die Spaltennamen
	public final static Vector<?> COLUMN_IDENTIFIERS = new Vector<Object>() {

		// serialVersionUID
		private static final long serialVersionUID = 4136566931496300757L;

		{
			add("id");
			add("datum");
			add("kommNr");
			add("kommName");
			add("strasse");
			add("hausnr");
			add("plz");
			add("gemeinde");
			add("telNr");
			add("bem 1");
			add("bem 2");
		}
	};

	// --------------------------------------------------------------------------------

	// Vector fur die Daten aus der DB
	protected Vector<Vector<String>> findAllPersons() {
		DBConnect.connect();
		Vector<Vector<String>> results = new Vector<Vector<String>>();
		try {
			Statement stmt = DBData.connection.createStatement();
			ResultSet rs = stmt.executeQuery("SELECT * FROM KOMMISSIONEN");

			while (rs.next()) {
				Vector<String> row = new Vector<String>();
				row.addElement(rs.getString("ID"));
				row.addElement(rs.getString("DATUM"));
				row.addElement(rs.getString("KOMMNR"));
				row.addElement(rs.getString("KOMMNAME"));
				row.addElement(rs.getString("STRASSE"));
				row.addElement(rs.getString("HAUSNR"));
				row.addElement(rs.getString("PLZ"));
				row.addElement(rs.getString("GEMEINDE"));
				row.addElement(rs.getString("TELNR"));
				row.addElement(rs.getString("BEMERKUNG1"));
				row.addElement(rs.getString("BEMERKUNG2"));
				results.add(row);
			}

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

		return results;
	}
	
	
	//------------------------------------------------------------------------------------------------
	
	public void searchButton() {
		// txtFields leeren
		txtFieldsLoeschen();
		
		// NullPointerException umgehen
		reset();
		
		JPanel panel = new JPanel(new FlowLayout());
		String text = JOptionPane.showInputDialog(panel);

		// gesuchte Zeilen markieren
        DefaultTableModel model = (DefaultTableModel) table.getModel();
        for (int i = 0; i < model.getRowCount(); i++) {
            for (int j = 0; j < model.getColumnCount(); j++) {
                if (model
                        .getValueAt(table.convertRowIndexToModel(i),
                                table.convertColumnIndexToModel(j))
                        .toString().indexOf(text) != -1) {
                    Rectangle r = table.getCellRect(i, 0, false);
                    table.scrollRectToVisible(r);
                    table.changeSelection(i, j, true, false);
                    for(int k=0; k<table.getColumnCount(); k++){
                        System.out.println(table.getValueAt(i, k));
                    }
                }
            }
        }
    }
	
	//--------------------------------------------------------------------------------------------
	
	public void datensatzAendern(){
		try {
			
			Statement stmt = DBData.connection.createStatement();
			String updateDBTable;
			String where;
			updateDBTable = "UPDATE KOMMISSIONEN SET ";
			where = " WHERE ID = " + txtFldId.getText();
			stmt.executeUpdate(updateDBTable + "kommnr = '"
					+ txtFldKommNr.getText() + "'" + ", "
					+ "kommname = '" + txtFldKommName.getText() + "'"
					+ ", " + "strasse = '" + txtFldStrasse.getText()
					+ "'" + ", " + "hausnr = '"
					+ txtFldHausNr.getText() + "'" + ", " + "plz = '"
					+ txtFldPlz.getText() + "'" + ", " + "gemeinde = '"
					+ txtFldGemeinde.getText() + "'" + ", "
					+ "telnr = '" + txtFldTelNr.getText() + "'" + ", "
					+ "bemerkung1 = '" + txtFldBem1.getText() + "'"
					+ ", " + "bemerkung2 = '" + txtFldBem2.getText()
					+ "'" + where);
			JOptionPane.showMessageDialog(null,
					"\u00C4nderung gespeichert");
		} catch (Exception e1) {
			JOptionPane.showMessageDialog(null, "Bitte w\u00E4hlen Sie einen Datensatz");
		}
		
		// Textdfelder loeschen
		txtFieldsLoeschen();
		callData();
	}
	
	//--------------------------------------------------------------------------------------------
	
	public void txtFieldsLoeschen(){
		
		txtFldId.setText(null);
		txtFldDatum.setText(null);
		txtFldKommNr.setText(null);
		txtFldKommName.setText(null);
		txtFldStrasse.setText(null);
		txtFldHausNr.setText(null);
		txtFldPlz.setText(null);
		txtFldGemeinde.setText(null);
		txtFldTelNr.setText(null);
		txtFldBem1.setText(null);
		txtFldBem2.setText(null);
	}
	
	public void datensatzLoeschen(){
		try {
			Statement stmt = DBData.connection.createStatement();
			String delDBTable;
			delDBTable = "DELETE FROM KOMMISSIONEN WHERE ID = "
					+ txtFldId.getText();
			stmt.execute(delDBTable);
			JOptionPane.showMessageDialog(null, "Datensatz gel\u00F6scht");
		} catch (Exception e1) {
			JOptionPane.showMessageDialog(null, "Bitte w\u00E4hlen Sie einen Datensatz");
		}
		// txtFields leeren
		txtFieldsLoeschen();
		callData();
	}
	
	//--------------------------------------------------------------------------------------------
	
	public void callData(){
		Vector<Vector<String>> results = findAllPersons();
		tabModel.setDataVector(results, COLUMN_IDENTIFIERS);
		tabModel.fireTableDataChanged();
		
		table.addMouseListener(new MouseAdapter() {
			@Override
			public void mouseClicked(MouseEvent evt) {
				
				int row = table.getSelectedRow();
				txtFldId.setText(table.getModel().getValueAt(row, 0).toString());
				txtFldDatum.setText(table.getModel().getValueAt(row, 1)
						.toString());
				txtFldKommNr.setText(table.getModel().getValueAt(row, 2)
						.toString());
				txtFldKommName.setText(table.getModel().getValueAt(row, 3)
						.toString());
				txtFldStrasse.setText(table.getModel().getValueAt(row, 4)
						.toString());
				txtFldHausNr.setText(table.getModel().getValueAt(row, 5)
						.toString());
				txtFldPlz.setText(table.getModel().getValueAt(row, 6)
						.toString());
				txtFldGemeinde.setText(table.getModel().getValueAt(row, 7)
						.toString());
				txtFldTelNr.setText(table.getModel().getValueAt(row, 8)
						.toString());
				txtFldBem1.setText(table.getModel().getValueAt(row, 9)
						.toString());
				txtFldBem2.setText(table.getModel().getValueAt(row, 10)
						.toString());
			}
		});
	}
	
	//--------------------------------------------------------------------------------------------
	
	public void reset(){
		createRowSorter((DefaultTableModel) table.getModel());
	}
	
	//-------------------------------------------------------------------------------------------

    private void createRowSorter(DefaultTableModel model) {
        sorter = new TableRowSorter<DefaultTableModel>(model);
        table.setRowSorter(sorter);
    }
    
    //-------------------------------------------------------------------------------------------
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Drag und drop aus einer JTable - bitte um Unterstützung AWT, Swing, JavaFX & SWT 2
S HPRO und UPRO gemeinsame JTABLE gemeinsamer RENDERER ? AWT, Swing, JavaFX & SWT 1
F Swing JTable - MultiHeader inkl. Eingabemöglichkeit AWT, Swing, JavaFX & SWT 1
S JTable - Feldinhalte anzeigen AWT, Swing, JavaFX & SWT 15
D Swing JTable Spaltenbreite AWT, Swing, JavaFX & SWT 1
W Gibt es einen "automatischen Listener" in Swing oder JTable oder der ATM-Klasse? AWT, Swing, JavaFX & SWT 14
G jTable - getSelectedRow() AWT, Swing, JavaFX & SWT 3
I JTable mit einem Button zu einer Detail Seite springen AWT, Swing, JavaFX & SWT 4
P JTable Listener für die Änderung einzelner Zellen oder Rows AWT, Swing, JavaFX & SWT 2
D Tastaturabfragen CTRL+t, CTRL+E bei eine JTable, bestehend aus JTextAteas AWT, Swing, JavaFX & SWT 4
P Checkboxes in JTable nicht editable AWT, Swing, JavaFX & SWT 9
F Best-Practise: JTable Text in Zelle zu groß AWT, Swing, JavaFX & SWT 2
izoards JTable in CSV File schreiben... AWT, Swing, JavaFX & SWT 23
Kohl Jedes Objekt einer JTable um ein Zeichen verkürzen AWT, Swing, JavaFX & SWT 7
I JTable, DefaultTableModel, zwei Zahlen multiplizieren. AWT, Swing, JavaFX & SWT 26
M JTABLE / wie oft wurde gewürfelt. AWT, Swing, JavaFX & SWT 1
F JTable vergrößern AWT, Swing, JavaFX & SWT 2
H JTable: Diverse NullPointer-Exceptions zur Laufzeit AWT, Swing, JavaFX & SWT 3
J Swing Werte des JTable werden nicht angezeigt AWT, Swing, JavaFX & SWT 9
T Swing JTable cellRenderer mit jpg Hintergrundfarbe lässt sich nicht ändern. AWT, Swing, JavaFX & SWT 1
HoT Einzelne Zelle in JTable Rahmen unten setzen AWT, Swing, JavaFX & SWT 24
B JTable Zellen zusammenfügen AWT, Swing, JavaFX & SWT 3
M Swing Cell Renderer für Zeilenumbruch in JTable AWT, Swing, JavaFX & SWT 0
H JTable im JSplitPane darstellen AWT, Swing, JavaFX & SWT 2
MadMax2506 Swing JTable lädt sehr lange AWT, Swing, JavaFX & SWT 1
D Zeilenumbruch in einer JTable AWT, Swing, JavaFX & SWT 9
R Swing JTable und Spaltenausrichtung AWT, Swing, JavaFX & SWT 8
G JTable füllen AWT, Swing, JavaFX & SWT 1
H JTable TableCellEditor-Problem AWT, Swing, JavaFX & SWT 0
W Swing JTable Zeilenumbruch innerhalb einer Zelle AWT, Swing, JavaFX & SWT 3
J Datensatz in jTable ausgeben AWT, Swing, JavaFX & SWT 3
M Swing Automatischer Editorstart in JTable-Zelle AWT, Swing, JavaFX & SWT 5
ralfb1105 Swing JTable aktualisieren AWT, Swing, JavaFX & SWT 5
adiko01 JTable: Nur markierte Zeilen aus der Tabelle in CSV exportiern AWT, Swing, JavaFX & SWT 9
M JTable.setDefaultRenderer(...) greift nicht AWT, Swing, JavaFX & SWT 0
J JTable: Eingabe in Tabellenzelle korrigieren AWT, Swing, JavaFX & SWT 4
T Problem mit JTable Sortierung AWT, Swing, JavaFX & SWT 2
D JTable nach INSERT aktualisieren /refreshen AWT, Swing, JavaFX & SWT 1
D MySQL Daten in JTable anzeigen AWT, Swing, JavaFX & SWT 2
H Swing Jtable extra spalte AWT, Swing, JavaFX & SWT 6
S Swing Rechteck über JTable zeichnen (per MouseListener) AWT, Swing, JavaFX & SWT 1
S Swing Mal wieder JTable Ansicht aktualisieren AWT, Swing, JavaFX & SWT 10
A JTable mit Daten füllen AWT, Swing, JavaFX & SWT 1
VfL_Freak Swing Einzelne Zeile in jTable selektieren klappt nicht AWT, Swing, JavaFX & SWT 7
N AWT jTable CellRenderer AWT, Swing, JavaFX & SWT 6
T Swing JTable valueChanged datensatz löschen AWT, Swing, JavaFX & SWT 1
0 Swing JTable aus anderer Klasse updaten AWT, Swing, JavaFX & SWT 5
S Jtable defaultRenderer wohin damit ? AWT, Swing, JavaFX & SWT 23
T Swing JTable / FocusListener AWT, Swing, JavaFX & SWT 0
it_is_all Warum wird die JTable im JDialog nicht angezeigt? AWT, Swing, JavaFX & SWT 1
L Swing JTable im Panel darstellen AWT, Swing, JavaFX & SWT 8
T Swing Double Click bei Buttons in JTable AWT, Swing, JavaFX & SWT 9
J addRow bei JTable AWT, Swing, JavaFX & SWT 6
M Jtable gibt -1 wert bei selectedRow und Column AWT, Swing, JavaFX & SWT 3
Meeresgott Swing JTable AWT, Swing, JavaFX & SWT 4
J JTable Selection Listener funktioniert nicht AWT, Swing, JavaFX & SWT 4
C Swing Daten in JTable wiedergeben per TableModel und MVC Pattern AWT, Swing, JavaFX & SWT 16
Z Swing Drag&Drop zwischen JTable und JTree AWT, Swing, JavaFX & SWT 4
Thallius JTable dynamisch Spaltenanzahl verändern AWT, Swing, JavaFX & SWT 2
Thallius JTable dynamisch laden? AWT, Swing, JavaFX & SWT 2
B Swing JTable sortieren AWT, Swing, JavaFX & SWT 2
T Swing JTable auslesen und befüllen AWT, Swing, JavaFX & SWT 8
B JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 1
J JTable und Suchlogik AWT, Swing, JavaFX & SWT 4
Viktim Swing JTable mit Tab verlassen AWT, Swing, JavaFX & SWT 1
F Swing Spaltenbreite einer Column eines JTable auslesen AWT, Swing, JavaFX & SWT 5
Viktim Swing JTable Mit Tab druch Zeilen Wechseln AWT, Swing, JavaFX & SWT 5
Thallius Warum refrehsed mein JTable nicht? AWT, Swing, JavaFX & SWT 5
Ghostman1711 Hinzufügen ausgewählter Dateinen des Filechoosers zu einem JTable AWT, Swing, JavaFX & SWT 9
S Swing JTable - Einzelne Rows einfärben AWT, Swing, JavaFX & SWT 11
M Wert einer Zelle aus JTable ziehen AWT, Swing, JavaFX & SWT 4
K JTable getValueAt() klappt nicht immer AWT, Swing, JavaFX & SWT 1
K JTable in extra Klasse, Zugriff in einer anderen klasse nicht möglich AWT, Swing, JavaFX & SWT 26
B Swing Tabelle(JTable) filtern swing GUI AWT, Swing, JavaFX & SWT 3
P JTable - bei Eingabe Selektion AWT, Swing, JavaFX & SWT 0
P Fokus auf Zelle in JTable AWT, Swing, JavaFX & SWT 1
S Swing Deselektion in JTable verhindern AWT, Swing, JavaFX & SWT 0
D Problem mit JTable AWT, Swing, JavaFX & SWT 1
N Swing Print JTable mit AbstractTableModel AWT, Swing, JavaFX & SWT 1
Ananaskirsche Swing jTable Reihen zuviel eingefügt AWT, Swing, JavaFX & SWT 12
P im JTable die Schriftfarbe ändern AWT, Swing, JavaFX & SWT 19
T Swing JTable wird nicht angezeigt AWT, Swing, JavaFX & SWT 4
S Dreiecke in bestimmte Zellen einer JTable AWT, Swing, JavaFX & SWT 9
LexeB4F Zelle in JTable gezielt einfärben AWT, Swing, JavaFX & SWT 4
LexeB4F JTable mehrere Zelle selektieren und inhalte Löschen.. Ideen gesucht AWT, Swing, JavaFX & SWT 1
D Swing JTable Renderer Grafikfehler AWT, Swing, JavaFX & SWT 0
K Swing JTable mit ImageIcon und Text in einer Zelle AWT, Swing, JavaFX & SWT 1
M Swing JTable GroupableHeader Background Color AWT, Swing, JavaFX & SWT 4
K Swing JTable updaten AWT, Swing, JavaFX & SWT 9
thet1983 Swing MySQL >> JTable AWT, Swing, JavaFX & SWT 5
J JTable bounds ändern durch resizing des Fensters AWT, Swing, JavaFX & SWT 9
F JTable Zellen-Hintergrund ändern AWT, Swing, JavaFX & SWT 7
O JTable linksbündig drucken (nicht der Zelleninhalt) AWT, Swing, JavaFX & SWT 2
Crazynet xls Datei in JTable AWT, Swing, JavaFX & SWT 3
O JTable ohne Rahmen printen AWT, Swing, JavaFX & SWT 3
L Swing JTable refresht die Column Namen nicht AWT, Swing, JavaFX & SWT 0
K JTable komplett durch andere ersetzen AWT, Swing, JavaFX & SWT 4
S JTable übernimmt Änderungen nicht AWT, Swing, JavaFX & SWT 2
Y JTable AWT, Swing, JavaFX & SWT 6
D Swing JCombobox in einem JTable vorbelegen AWT, Swing, JavaFX & SWT 4

Ähnliche Java Themen

Neue Themen


Oben