DB-Abfrage ins Nirvana?

Status
Nicht offen für weitere Antworten.

Jeans78

Mitglied
Hi

ich versuche schon seit Stunden eine "einfache" DB-Abfrage in Java zu programmieren. Leider funzt das ganze immer noch nich so wie ich mir das vorstelle.

Vorstellung: JComboBox bietet verschiedene Industriebranchen zur Auswahl an, welche in DB hinterlegt sind (funzt). Nach Auswahl einer Industriebranche wird wird erneut eine DB-Abfrage ausgeführt u. eine zweite JComboBox zeigt die Companies der ausgewählten Branche an.

Folgende Fehler tretten auf:

1. Nach Auswahl einer Industriebranche wird das Ergebnis der Abfrage zweimal ausgegeben.

2. Zweite JComboBox wird nicht ausgegeben - Fehler in zweiter Abfrage!?

Mich würde noch interessieren ob man den Quellcode nich irgendwie auslagern kann auf verschiedene Klassen, da n bischen unübersichtlich..
Kann mir da jemand weiterhelfen!?
Danke

Code:
import java.awt.*;
import java.awt.event.*;
import javax.swing.JFrame;
import javax.swing.*;
import java.sql.*;
//import org.jfree.ui.RefineryUtilities;

public class analysisListener implements ActionListener 
{
    private JFrame oldFrame;
    private JPanel oldContent, oldPanel;
    private JComboBox choseIndustry = new JComboBox();
    private JComboBox choseCompany = new JComboBox();
    private JPanel selectPanel = new JPanel();
    
    public analysisListener(JPanel c) 
    {
        
        oldContent = c;
        
    }

//     public void actionPerformed (ActionEvent e) 
//     {
//         newFrame.setVisible(true);
//         oldFrame.setVisible(false);
//     }
//     
    public void actionPerformed (ActionEvent e) 
    {
        oldContent.removeAll();
        oldContent.setLayout(new BorderLayout());
        
        
        selectPanel.setLayout(new FlowLayout(FlowLayout.CENTER));
        
        JLabel industryLabel = new JLabel("Industry:");
        selectPanel.add(industryLabel);
        
        Database db = new Database();
        try
        {
        String sql = "SELECT industry_sector FROM industry";
        db.request(sql);
        
        while (db.result.next())
            {
               System.out.println("found a result");
               String  industry = db.result.getString("industry_sector");
               choseIndustry.addItem(industry);
            } //end while industry

               selectPanel.add(choseIndustry);
               
               choseIndustry.addItemListener(new ItemListener()
               {
                   public void itemStateChanged(ItemEvent e) 
                   {
                        int which = choseIndustry.getSelectedIndex();
                        String selectedIndustry =  (String)choseIndustry.getItemAt(which);
                        System.out.println("Chosen industry: " +selectedIndustry);              // HIER wird das Ergebnis 2x ausgegeben.
//////////////////////////////////////////
                        if(e.getStateChange() == ItemEvent.SELECTED)
                        {
                            Database db = new Database();
                            try
                            {
                                String sql = "SELECT companies.company_name FROM companies, industry WHERE industry.industry_sector = selectedIndustry AND industry.industry_sector_id = companies.industry_sector_id";
                                db.request(sql);
        
                                while (db.result.next())   //HIER passiert gar nichts mehr
                                {
                                    String  company = db.result.getString("company_name");
                                    choseCompany.addItem(company);
                                    selectPanel.add(choseCompany);
                                    
                                    //choseCompany.addItemListener(new ItemListener());
                                }
                            }
                                catch(SQLException ex)
                                {
                                    System.out.println("* Cannot create dataset! *");
                                    ex.printStackTrace();
                                }
                        
                            } //end if
/////////////////////////////////
                     }//end method itemStateChanged
                    }//end inner class Item Listener
                
              );//end call addItemListener
            
        } //end try industry
        catch(SQLException ex)
        {
            System.out.println("* Cannot create dataset! *");
            ex.printStackTrace();
        }
        
         oldContent.add(selectPanel, BorderLayout.WEST);
         oldContent.revalidate(); 
      } 
      
    }
 

foobar

Top Contributor
Oh je, das ist ja alles Kraut und Rüben. Du solltest erstmal GUI und DB-Schicht voneinander trennen. Guck dir dazu mal das DAO-Pattern an. Ausserdem fügst du bei jedem Klick einen ItemListener hinzu, das ist bestimmt nicht das was du machen willst.
 

Jeans78

Mitglied
Kraut u. Rüben - hmm, das dachte ich mir schon..
Bei jedem Klick ItemListener!? Is doch aber ausserhalb der while-Schleife.. wo muss er dann hin?
DAO-Pattern werd ich gleich in Angriff nehmen.

Auf welche Art und weise soll mein 1. Fehler weg sein!? Meinst du mit hinzufügen v. ItemListener bei implements??

Danke schon mal für die Hinweise
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
L If Abfrage Java Basics - Anfänger-Themen 4
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
W if-Abfrage bei ArrayList-Methodenaufrufen - Wie löse ich das? Java Basics - Anfänger-Themen 6
B Automatisierte Ausgabe (Schleife, If-Abfrage?) Java Basics - Anfänger-Themen 24
I ResultSet aus meiner SQL-Abfrage in einem JTextfield ausgeben. Java Basics - Anfänger-Themen 1
X Enum Abfrage ohne if, for, while oder switch Java Basics - Anfänger-Themen 21
G Taschenrechner ergibt Fehler in if-Abfrage Java Basics - Anfänger-Themen 6
S Interaktive Abfrage, Hilfe mit Schleifen! Java Basics - Anfänger-Themen 6
P Amazon SQS abfrage Java Basics - Anfänger-Themen 1
Marlena Bauer IBAN generieren (Deutschland) aus Abfrage von BLZ und Kontonummer? Java Basics - Anfänger-Themen 31
M Abfrage j/n und Bildschirm löschen Java Basics - Anfänger-Themen 3
S Und-Abfrage mit mehreren Ungleich-Operatoren Java Basics - Anfänger-Themen 17
O if Abfrage erkennt String nicht Java Basics - Anfänger-Themen 1
NeoLexx Abfrage mit instanceof führt zu unerwarteten Wert Java Basics - Anfänger-Themen 9
N Bedinugng If-Abfrage wird nie erfüllt Java Basics - Anfänger-Themen 4
L boolean-Abfrage enumeration Java Basics - Anfänger-Themen 3
Y Methoden Wie kann ich eine if-Abfrage bei Setters bauen? Java Basics - Anfänger-Themen 6
S Streams - Abfrage absteigend sortieren Java Basics - Anfänger-Themen 11
F If Abfrage gibt falsches Ergebnis.... Java Basics - Anfänger-Themen 6
F POST-Request mit json - Abfrage mit Java Java Basics - Anfänger-Themen 2
C Javafunktion zur Abfrage eines Quellcodes Java Basics - Anfänger-Themen 15
A JOPtionPaneOptionDialog Abfrage welcher Button gedrückt wurde? Java Basics - Anfänger-Themen 8
B Folgende Abfrage dynamisch programmieren? Java Basics - Anfänger-Themen 8
G if Abfrage: Nicht jeder Fall berücksichtigt Java Basics - Anfänger-Themen 2
I Nur auf Abfrage von einer Text Datei einlesen Java Basics - Anfänger-Themen 11
J Erste Schritte if Abfrage von JButton in 2. Klasse Java Basics - Anfänger-Themen 27
S If Abfrage nur mit bestimmter Initialisierung? Java Basics - Anfänger-Themen 8
Z Boolean Abfrage in einer for each Schleife Java Basics - Anfänger-Themen 2
deatzi Variable aus If Abfrage später nutzen Java Basics - Anfänger-Themen 4
C Instanz einer Klasse während if-Abfrage erzeugen und bei zweiter if-Abfrage wiederverwenden Java Basics - Anfänger-Themen 6
S Backspace Abfrage funktioniert nicht Java Basics - Anfänger-Themen 4
F Interface JFrame mit if-Abfrage automatisch schließen lassen? Java Basics - Anfänger-Themen 3
R Abfrage von Variablen in Unterklassen einer ArrayList Java Basics - Anfänger-Themen 9
G Passwort und Passwort wiederholen in if-Abfrage vergleichen Java Basics - Anfänger-Themen 15
P Altklausur: Abfrage der Summe Java Basics - Anfänger-Themen 9
N Methoden Attribut Abfrage eines anderen Objektes Java Basics - Anfänger-Themen 36
D MySQL Abfrage in JTable speichern Java Basics - Anfänger-Themen 43
D SQL Abfrage anpassen Java Basics - Anfänger-Themen 17
H For-Schleife innerhalb If-Abfrage? Java Basics - Anfänger-Themen 3
F Abfrage ob Eingabe eine Zahl ist Java Basics - Anfänger-Themen 3
O Datentypen Volle 16 Bit eines Short für flags Abfrage nutzen Java Basics - Anfänger-Themen 11
S Input/Output Doppelte Input-Abfrage Java Basics - Anfänger-Themen 3
S Input/Output Programm läuft nach input-Abfrage nicht weiter. Java Basics - Anfänger-Themen 2
M Variablen Eine etwas andere if Abfrage ! Java Basics - Anfänger-Themen 10
H if-Abfrage, ungleich und falscher true Wert? Java Basics - Anfänger-Themen 11
F Ja Nein Abfrage und andere Probleme Java Basics - Anfänger-Themen 5
OlafHD Fehler Bei der if Abfrage Java Basics - Anfänger-Themen 5
quecksilver if-Abfrage in main ausführen Java Basics - Anfänger-Themen 4
D if-Abfrage Java Basics - Anfänger-Themen 12
J Abfrage für Programmwiederholung Java Basics - Anfänger-Themen 2
K Alternative zur If-Abfrage Java Basics - Anfänger-Themen 3
M Java als Webanwendung mit Datenbank abfrage Java Basics - Anfänger-Themen 3
D Abfrage ob Variableninhalt korrekt Java Basics - Anfänger-Themen 5
W Vergleich mit If-Abfrage nur für Zahlen bis 07 möglich - Warum? Java Basics - Anfänger-Themen 7
D Operatoren IF Abfrage liefert falsches Ergebnis Java Basics - Anfänger-Themen 4
X Ja nein abfrage? Java Basics - Anfänger-Themen 9
A Erste Schritte Problem bei meiner if-Abfrage! Java Basics - Anfänger-Themen 5
M Enum-Variabel-Abfrage funktioniert nicht? Java Basics - Anfänger-Themen 2
S Java Counter: nur 1 mal hochzählen auch wenn Abfrage mehrmals zutrifft. Java Basics - Anfänger-Themen 1
E Erste Schritte [Noob-Frage] Meine If-Abfrage macht nicht, was sie soll... Java Basics - Anfänger-Themen 2
C Abfrage nach einem Bild im Array Java Basics - Anfänger-Themen 9
A Key Event - Abfrage von 2 gedrückten Tasten Java Basics - Anfänger-Themen 6
T Klasse für Google-Abfrage Java Basics - Anfänger-Themen 9
Z If abfrage - Minimum 0 Java Basics - Anfänger-Themen 9
J Abfrage versetzen Java Basics - Anfänger-Themen 2
D Methoden Abfrage ob ein Wert bereits vorhanden ist Java Basics - Anfänger-Themen 1
thet1983 if() Abfrage Java Basics - Anfänger-Themen 2
A charAt(x)-Abfrage lässt bei Strings<x das Pgrogramm abstürzen. Kann man das verhindern? Java Basics - Anfänger-Themen 4
Uzi21 if - else Abfrage Java Basics - Anfänger-Themen 6
T Index-Abfrage von Pi Java Basics - Anfänger-Themen 5
H Erste Schritte If Abfrage Java Basics - Anfänger-Themen 3
B If Abfrage mit Passwort und Username Java Basics - Anfänger-Themen 2
U einlesen, abfrage Java Basics - Anfänger-Themen 25
T SQL Abfrage Läuft nicht Java Basics - Anfänger-Themen 5
N Probleme mit ActionListener und Logischer Abfrage Java Basics - Anfänger-Themen 4
F Erste Schritte IF-Abfrage fehlerhaft Java Basics - Anfänger-Themen 9
O Downloaden: Trotz If Abfrage wird Datei heruntergeladen Java Basics - Anfänger-Themen 2
D jProgressBar soll bei 100% sein wenn sql Abfrage inkl. jTable schreiben fertig ist... Java Basics - Anfänger-Themen 5
H if-Abfrage double wert Java Basics - Anfänger-Themen 5
M Erstes Prog. OS Abfrage Java Basics - Anfänger-Themen 9
I Einlese Abfrage zweier Variablen in einem Fenster Java Basics - Anfänger-Themen 6
B Boolean abfrage Java Basics - Anfänger-Themen 3
D Variablen Rücksprung nach If Abfrage Java Basics - Anfänger-Themen 16
T If- Abfrage Java Basics - Anfänger-Themen 8
P Taschenrechner , IF-Abfrage Java Basics - Anfänger-Themen 12
D if-Abfrage Java Basics - Anfänger-Themen 6
G Einfache if-Abfrage der Main-Argumente Java Basics - Anfänger-Themen 3
C If abfrage zu getBackground Java Basics - Anfänger-Themen 2
T abfrage eines Integer Array s Java Basics - Anfänger-Themen 5
feardorcha boolean array false - true - Abfrage Java Basics - Anfänger-Themen 10
G Adminrechte abfrage Java Basics - Anfänger-Themen 5
S Abfrage Objekt-Array nach Datentypen Java Basics - Anfänger-Themen 6
R If-Abfrage, || funktioniert nicht Java Basics - Anfänger-Themen 4
S TabbedPane: nach Abfrage oldTab selektieren Java Basics - Anfänger-Themen 5
B Abfrage mittels Variable vereinfachen Java Basics - Anfänger-Themen 6
C Treffer Abfrage Java Basics - Anfänger-Themen 19
M nach jar export keine db abfrage möglich Java Basics - Anfänger-Themen 2
T Datenbank Abfrage Exception Null Java Basics - Anfänger-Themen 2
J Erste Schritte Im Tante-Emma-Laden mehrere Artikel kaufen mit if-Abfrage Java Basics - Anfänger-Themen 24

Ähnliche Java Themen

Neue Themen


Oben