JTable Probleme beim Sortieren von Zahlen.

dennisT

Mitglied
Hi, ich habe probleme eine JTable mit Werten aus einer Datenbank zu Sortieren. Text geht, aber Zahlen leider nicht.
Sie werden so sortiert "1,10,2,20"

Hier ist der Aufbaue der Tabelle:
Java:
JTable jt_tabelle;
DefaultTableModel tabelle;
jt_tabelle = new JTable(tabelle);

Java:
tabelle.setDefaultRenderer(Object.class, new MyRenderer());
try{           
      Connection con = DriverManager.getConnection("jdbc:hsqldb:file:Datenbank/....; shutdown=true", "ROOT", "" );
      Statement stmt = con.createStatement();
      ResultSet rslt = stmt.executeQuery("select ID,Name,Preis fromTABELLE"); 
     
      
      tabelle = new DefaultTableModel(){
        public boolean isCellEditable(int row, int column){
          return false;
        }
      };
      
      Vector<String> clmHeader = new  Vector<String>();
      Vector<Object> dataVector = new  Vector<Object>();
      
      ResultSetMetaData rsmd = rslt.getMetaData();
      int clmCnt = rsmd.getColumnCount();
      for(int i = 1; i <= clmCnt;i++){
        clmHeader.addElement(rsmd.getColumnName(i));
      }
      while(rslt.next()){
        Vector<String> rowVector = new  Vector<String>();
        for(int i = 1; i <= clmCnt; i++){
          rowVector.addElement(rslt.getString(i));
        }
        dataVector.addElement(rowVector);
      }
      tabelle.setDataVector(dataVector,clmHeader);
      stmt.close();
      con.close();
    }
    catch (Exception f){}
    jt_tabelle.setModel(tabelle);
    jt_tabelle.setAutoCreateRowSorter(true);
    jt_tabelle.getRowSorter().toggleSortOrder(1);

Das ist jetzt der Ursprungscode. Ich habe schon viel geändert und rumprobiert, aber es einfach nicht geschafft. Der wert Preis ist eine Kommazahl btw, also wenn das machbar ist, beides sortierbar zu machen, wäre es wunderbar :)
 

Dompteur

Top Contributor
Du hast folgendes deklariert: Vector<String> rowVector
Daher werden alle Spalten auch in der Tabelle als Strings interpretiert. Hier musst du ansetzen.
 

dennisT

Mitglied
Okay, habe es mal weiterversucht:

Java:
tabelle.setDefaultRenderer(Object.class, new MyRenderer());
try{           
      Connection con = DriverManager.getConnection(...);
      Statement stmt = con.createStatement();
      ResultSet rslt = stmt.executeQuery("select ID,Name,Preis fromTABELLE"); 
 
      tabelle = new DefaultTableModel() {
        @Override
        public Class getColumnClass(int column) {
          
          switch (column) {
            case 0:
            return Integer.class;
            case 1:
            return String.class;
            case 2:
            return Double.class;
            default:
            return String.class;
          }
        }  
        public boolean isCellEditable(int row, int column){
          return false;
        }     
      };

      Vector<String> clmHeader = new  Vector<String>();
      Vector<Object> dataVector = new  Vector<Object>();
 
      ResultSetMetaData rsmd = rslt.getMetaData();
      int clmCnt = rsmd.getColumnCount();
      for(int i = 1; i <= clmCnt;i++){
        clmHeader.addElement(rsmd.getColumnName(i));
      }
      while(rslt.next()){
        Vector<Object> rowVector = new  Vector<Object>();
        for(int i = 1; i <= clmCnt; i++){
          rowVector.addElement(rslt.getObject(i));
        }
        dataVector.addElement(rowVector);
      }
      tabelle.setDataVector(dataVector,clmHeader);
      stmt.close();
      con.close();
    }
    catch (Exception f){}
    jt_tabelle.setModel(tabelle);
    jt_tabelle.setAutoCreateRowSorter(true);
    jt_tabelle.getRowSorter().toggleSortOrder(1);

Nun sortiert er die Zahlen bei ID wie es soll. (Die Ausrichtung der Zahlen ist nun rechtsbündig, ein schneller Tipp, wie ich es wieder linksbündig bekommen kann wäre super :) )
Nur mit dem Preis habe ich noch Probleme, habe ich denn richtig verstanden, dass case die Position in der Tabelle dastellt? An dritter Position kommt ja der Preis in dieser Art (z.B. 20.50). So bekomme ich aber diesen Fehler:

Exception in thread "AWT-EventQueue-0" java.lang.IllegalArgumentException: Cannot format given Object as a Number
at java.text.DecimalFormat.format(DecimalFormat.java:507)
at java.text.Format.format(Format.java:157)
at javax.swing.JTable$DoubleRenderer.setValue(JTable.java:5356)
at javax.swing.table.DefaultTableCellRenderer.getTableCellRendererComponent(DefaultTableCellRenderer.java:257)
at javax.swing.JTable.prepareRenderer(JTable.java:5723)
at javax.swing.plaf.basic.BasicTableUI.paintCell(BasicTableUI.java:2114)
at javax.swing.plaf.basic.BasicTableUI.paintCells(BasicTableUI.java:2016)
at javax.swing.plaf.basic.BasicTableUI.paint(BasicTableUI.java:1812)
at javax.swing.plaf.ComponentUI.update(ComponentUI.java:161)
at javax.swing.JComponent.paintComponent(JComponent.java:780)
at javax.swing.JComponent.paint(JComponent.java:1056)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JViewport.paint(JViewport.java:728)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JLayeredPane.paint(JLayeredPane.java:586)
at javax.swing.JComponent.paintChildren(JComponent.java:889)
at javax.swing.JComponent.paint(JComponent.java:1065)
at javax.swing.JComponent.paintToOffscreen(JComponent.java:5219)
at javax.swing.RepaintManager$PaintManager.paintDoubleBuffered(RepaintManager.java:1572)
at javax.swing.RepaintManager$PaintManager.paint(RepaintManager.java:1495)
at javax.swing.RepaintManager.paint(RepaintManager.java:1265)
at javax.swing.JComponent._paintImmediately(JComponent.java:5167)
at javax.swing.JComponent.paintImmediately(JComponent.java:4978)
at javax.swing.RepaintManager$4.run(RepaintManager.java:824)
at javax.swing.RepaintManager$4.run(RepaintManager.java:807)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:807)
at javax.swing.RepaintManager.paintDirtyRegions(RepaintManager.java:782)
at javax.swing.RepaintManager.prePaintDirtyRegions(RepaintManager.java:731)
at javax.swing.RepaintManager.access$1300(RepaintManager.java:64)
at javax.swing.RepaintManager$ProcessingRunnable.run(RepaintManager.java:1720)
at java.awt.event.InvocationEvent.dispatch(InvocationEvent.java:311)
at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:749)
at java.awt.EventQueue.access$500(EventQueue.java:97)
at java.awt.EventQueue$3.run(EventQueue.java:702)
at java.awt.EventQueue$3.run(EventQueue.java:696)
at java.security.AccessController.doPrivileged(Native Method)
at java.security.ProtectionDomain$1.doIntersectionPrivilege(ProtectionDomain.java:75)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:719)
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:201)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)
 

Dompteur

Top Contributor
Du hast wahrscheinlich noch ein Problem mit dem Dezimalpunkt. Abhängig von der Lokalisierung kannst du ja die deutsche (= Komma) oder englische (= Punkt) Einstellung wählen.
Wenn dort "20.50" steht und du als Default "de" eingestellt hast, dann kann er das klarerweise nicht verstehen.
 

dennisT

Mitglied
Erstmal danke für die ganze Hilfe, ich habe es nun so umgesetzt und es scheint zu klappen:

Java:
while(rslt.next()){
        Vector<Object> rowVector = new  Vector<Object>();
        for(int i = 1; i <= clmCnt; i++){
          if (i==8) {                   //8=Spalte mit den Double Werten
            rowVector.addElement(rslt.getDouble(i));
          } 
          else{
            rowVector.addElement(rslt.getObject(i));
          }      
        }
        dataVector.addElement(rowVector);
      }
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Probleme beim zykl. aktulisieren von Daten in JTable Java Basics - Anfänger-Themen 3
D Probleme bei der Column-Breite einer JTable Java Basics - Anfänger-Themen 4
J Probleme mit Klassenmodell für JTable Java Basics - Anfänger-Themen 10
N Probleme mit JTable Java Basics - Anfänger-Themen 8
G RadioButton in JTable macht Probleme Java Basics - Anfänger-Themen 5
N JTable Probleme Java Basics - Anfänger-Themen 10
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
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
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
S JTable dynamisch mit Datenbankinhalten füllen Java Basics - Anfänger-Themen 6
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

Ähnliche Java Themen

Neue Themen


Oben