JTable Java 1.6 Filtering TableRows EDIT(!)

Status
Nicht offen für weitere Antworten.

FenchelT

Bekanntes Mitglied
Hallo zusammen,

durch Zufall habe ich soeben diesen Artikel in der grossen weiten Online Welt gefunden:
http://java.sun.com/developer/JDCTechTips/2005/tt1115.html#2

In diesem Beispiel wird gezeigt, wie auf einfache Weise ein Filter implementiert werden kann, der automatisch in jeder
Spalte nach der getaetigten Eingabe sucht.

Ich hatte sowas vor einiger Zeit mal sehr umstaendlich ueber ein FilteredRowSet abgebildet; funktioniert auch, gefaellt mir aber nicht so besonders.

Nun scheint mir das dort abgebildete genau dem zu entsprechen, was ich eigentlich gerne umsetzen wollte.

Mein Problem ist nun, dass dies wieder ein Beispiel ist, welches fix mit dem DefaultTableModell arbeitet. (ich hatte seinerzeit von AbstractTableModel abgeleitet, was hier aber nicht funktionieren soll)

Kurzum:
Die Daten die ich darstellen moechte, kommen aus einer DB und liegen in einem ResultSet vor.
Wie bekomme ich diese Daten nun am einfachsten in einen Datentypen, der vom DefaultTableModell akzeptiert wird?


Vielen Dank fuer eure Tipps und Unterstuetzung


EDIT:
Oops, ganz vergessen zu erwaehnen. MIr ist bekannt, dass ich das ganze in einer for Schleife in einen Datentypen Object[]
ueberfuehren kann. Mich wuerde eher interessieren, ob es da in Java 1.5 / 1.6 bereits fertige Klassen#Methoden fuer gibt.

Danke
 
I

immavy

Gast
hi,
vieleicht ist das ja das richtige für dich.

gruss
mavy


Code:
import java.io.*; 
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.*; 

import javax.swing.*; 
import javax.swing.table.*; 

/* 
Es sind nicht alle Funktionen ausprogrammiert (so wie setValueAt(..) usw! 

Es sind nur diese Funktionen ausprogrammiert, die man auch braucht fürs auslesen/anzeigen 
und für das sortieren! 


(das Statement braucht außerdem noch eine Verbindung! - man könntes mitübergeben bei der loadfunktion!) 
*/ 

public class KundeTabModel extends DefaultTableModel{ 
  /**
	 * 
	 */
	private static final long serialVersionUID = 1L;

	String[] columnNames = 
      { 
		"Kundenkürzel" , "Kunden-Nr", "Kunde", "Strasse", "Ort", "Land","VAT-Nr.","Homepage"}; //Überschriften der Tabelle 

  private Object data[]; 
//  private Statement stm = null; 
  private ResultSet rs = null; 

  private ArrayList<Haupt> ar = null; 
  private boolean bErg = true; 
  Object[][] rawData;

  
  /************************************************************************** 
   * Konstruktor für TabModel, indem die Spaltenbezeichnungen definiert werden 
   * und initDateTable wird aufgerufen 
   *************************************************************************/ 
  public KundeTabModel(Object[][] rowData){
	  
	  
  }
  public KundeTabModel() 
  { 
    try 
    { 
      columnNames[0] = "Kundenkürzel"; 
      columnNames[1] = "Kunden-Nr"; 
      columnNames[2] = "Kunde"; 
      columnNames[3] = "Strasse"; 
      columnNames[4] = "Ort"; 
      columnNames[5] = "Land"; 
      columnNames[6] ="VAT-Nr.";
      columnNames[7] ="Homepage";
    } 
    catch (Exception ex) 
    { 
      ex.printStackTrace(); 
    } 

  } 
  

  /*************************************************************************** 
   * Spaltenanzahl 
   * @return Anzahl der Spalten 
   *************************************************************************/ 
  public int getColumnCount() 
  { //Anzahl der Spalten 
    return columnNames.length; 
  } 

  /*************************************************************************** 
   * Zeilenanzahl 
   * @return Anzahl der Zeilen 
   *************************************************************************/ 
  public int getRowCount() 
  { //Anzahl der Zeilen 
    if (data == null) 
      return 0; 
    return (data.length); 
  } 

  /************************************************************************** 
   * Name einer Spalte 
   * @param iCol Position der Spalte 
   * @return Name der übergebenen Spalte 
   *************************************************************************/ 
  public String getColumnName(int iCol) 
  { //Name der Spalten 
    return columnNames[iCol]; 
  } 

  /************************************************************************** 
   * Wert einer Spalte in einer bestimmten Zeile 
   * @param iRow Index der Zeile 
   * @param iCol Position der Spalte 
   * @return Wert an der Stelle row / col 
   *************************************************************************/ 
 public Object getValueAt(int iRow, int iCol) 
  { //Retouniert Wert an bestimmter Stelle 
    Object objRet = null; 

    if (iRow < data.length && data[iRow] != null) // gibt die Objekte zurück 
    { 
      Haupt pl = (Haupt) data[iRow]; 
      switch (iCol) 
      { 
        case 0: 
          objRet = pl.firmenk;  
          break; 
        case 1: 
          objRet = Integer.toString(pl.kd_nr); 
          break; 
        case 2: 
          objRet = pl.kunde; 
          break; 
        case 3: 
          objRet = pl.strasse; 
          break; 
        case 4: 
          objRet = pl.ort; 
          break; 
        case 5: 
          objRet = pl.land; 
          break; 
        case 6: 
          objRet = pl.vta_nr; 
          break;
        case 7: 
          objRet = pl.hp; 
          break;
      } 
    } 
    return objRet; 
  } 
  

  /************************************************************************* 
   * Hinweis: Je für Programm abänderbar 
   * @param row Index der Zeile 
   * @param col Position der Spalte 
   * @return false für not editable, true für editable 
   *************************************************************************/ 
  public boolean isCellEditable(int row, int col) 
  { 
	  return false; 
  } 


  /************************************************************************** 
   * Lädt die Daten von der Datenbank einmal in datatable und einmal in einen array 
   * und danach in data 
   *************************************************************************/ 
  public void loadFromADatabase() 
  { 
	DatabaseConnection dbcon = new DatabaseConnection();
	Connection con = null;
	con = dbcon.openConnection();
    try 
    { 
      Statement stm = con.createStatement();
      ar = new ArrayList<Haupt>(); 

      //führt den SQL Befehl aus 
      rs = stm.executeQuery("SELECT * FROM haupt"); //man kann die Daten auch anders holen, und zwar File einlesen, usw 
      
      if (!rs.next()) // falls es kein nächstes gibt 
        bErg = false; 

      if (bErg) // default mäßig auf true, falls es kein Ergebnis gibt geht er nicht rein 
      { 
        do 
        { 
          bErg = true; 
          Haupt pl = new Haupt(); 
          //hauptTabelle
          pl.kd_nr = rs.getInt(2); 
          pl.firmenk = rs.getString(3); 
          pl.kunde = rs.getString(4); 
          pl.strasse = rs.getString(5); 
          pl.ort = rs.getString(6); 
          pl.land= rs.getString(7);
          pl.vta_nr=rs.getString(8);
          pl.hp=rs.getString(9);
          //Ansprechpartner
          
          ar.add(pl); //fügt die Klasse in den Array hinzu 

        } 
        while (rs.next()); //solange es einen nächsten gibt 
      } 

      rs.close();
     
      stm.close(); 
      data = ar.toArray(); // Array wird in ein Objekt geholt um es nachher für die Table auszugeben 
      fireTableDataChanged(); // lässt die Tabelle neu zeichnen 
      fireTableStructureChanged();
      dbcon.closeConnection();
    } 
    catch (Exception ex) 
    { 
      ex.printStackTrace(); 
    } 
  } 

  /************************************************************************* 
   * Beispiel lädt Daten aus einer Datei die mit ; getrennt sind 
   * @param fFile die Datei 
   ************************************************************************/ 
  public void loadFromAFile(File fFile) 
  { 
    int iAnzToken; // abfrage auf wieviel ; die linie hat 
    StringTokenizer token; 
    String line = "",buf[]; 

    try{ 
      //reader um aus der Datei zu lesen 
      BufferedReader br = new BufferedReader( 
          new InputStreamReader( 
          new FileInputStream(fFile))); 

      //Arrayliste neu initialisieren 
      ar = new ArrayList<Haupt>(); 
      while ( (line = br.readLine()) != null) 
      { 
        token = new StringTokenizer(line, ";", false); //wird davon ausgegangen das es mit ; getrennt ist 
        iAnzToken = token.countTokens(); 
        buf = new String[iAnzToken]; 
        for(int x = 0; x != iAnzToken && token.hasMoreTokens(); x++) 
          buf[x] = token.nextToken(); 

        Haupt pl = new Haupt(); 
        pl.kd_nr = Integer.parseInt(buf[0]); 
        pl.firmenk = buf[1]; 
        pl.kunde = buf[2]; 
       
        pl.strasse = buf[4]; 
        pl.ort = buf[5]; 
        pl.land= buf[6];
    
        pl.vta_nr=buf[10];
        pl.hp=buf[11];

        ar.add(pl); //fügt die Klasse in den Array hinzu 
      } 

     } 
     catch(Exception ex) 
     { 
       ex.printStackTrace(); 
     } 
  } 

  /**************************************************************************** 
   * Funktion liefert ein JTable zurück 
   * @return ein JTable objekt 
   ***************************************************************************/ 
  public JTable getModel() 
  { 
    return new JTable(this); 
  } 

  /**************************************************************************** 
   * Setzt das Model neu! 
   * @param TableModel1 das tablemodel das gesetzt werden soll 
   ***************************************************************************/ 
  public void setModel(TableModel TableModel1) 
  { 
    ar = new ArrayList<Haupt>(); //alles neu schreiben 
    for (int x = 0; x != TableModel1.getRowCount(); x++) 
    { 
      //neues Objekt zum Einhängen 
      Haupt pl = new Haupt(); 
      for (int y = 0; y != TableModel1.getColumnCount(); y++) 
      { 
        switch (y) 
        { 
          case 0: 
            pl.kd_nr = Integer.parseInt(TableModel1.getValueAt(x, y).toString()); 
            break; 
          case 1: 
            pl.firmenk = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 2: 
            pl.kunde = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 3: 
            pl.strasse = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 4: 
            pl.ort = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 5: 
            pl.land = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 6: 
            pl.vta_nr = TableModel1.getValueAt(x, y).toString(); 
            break; 
          case 7: 
            pl.hp = TableModel1.getValueAt(x, y).toString(); 
            break; 
        } 
      } 
      ar.add(pl); 
    } 

   data = ar.toArray(); // Array wird in ein Objekt gespeichert um es nachher für die Table auszugeben 
	}
  class Haupt 
  { 
    int kd_nr; 
    String firmenk; 
    String kunde; 
    String strasse; 
    String ort; 
    String land; 
    String vta_nr;
    String hp;
  }
  
  
}
 

FenchelT

Bekanntes Mitglied
Hallo,

sorrry erstmal, dass ich mich erst jetzt melde, stecke im Jahresabschluss fest.

Ich werde mir Dein Beispiel bei naechster Gelegenheit mal in Ruhe zu Gemuete fuehren, finde es auf den ersten Blick aber doch ziemlich komplex.

Vllt. ist mein zwiter Eindruck ja anders :wink:



Danke nochmals und viele Gruesse
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Developer_X Java JTable - Combobox + Checkbox - Cellrenderer + Editor AWT, Swing, JavaFX & SWT 3
A JTable und java.lang.IndexOutOfBoundsException AWT, Swing, JavaFX & SWT 3
D Swing Java - JTable AWT, Swing, JavaFX & SWT 7
M Java Applet JTable/JList AWT, Swing, JavaFX & SWT 6
G JTable sortieren (Java 1.5) AWT, Swing, JavaFX & SWT 4
ARadauer jtable drucken unter java 1.3 AWT, Swing, JavaFX & SWT 2
W JTable und die java.sql.xxx Datum-/Zeitformate AWT, Swing, JavaFX & SWT 5
O JTable in Java 1.4/Java 1.5 und MULTIPLE_INTERVAL_SELECTION AWT, Swing, JavaFX & SWT 2
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

Ähnliche Java Themen

Neue Themen


Oben