Ein SQLStatement mit Unterabfrage in Java

JonnieWalker

Bekanntes Mitglied
Leute ich hab mal eine Frage.
Hab diese Methode hier, die mir Wörter die mehr als einmal vorkommen anzeigt.
Mein SQL-Statement funktioniert in SQLExpress super, dort bekomm ich die Daten die mehr
als einmal vorkommen sauber untereinander.

Nur hier mit Java hab ich Probleme.
Es wird mir nichts angezeigt!
Hat mein Statement damit zu tun?

Methode aus der Klasse Datenbanken(Hier ist auch die Unterabfrage):
Java:
public ArrayList<Words> getDoppelteWoerter() {
        Words Datensatz;
        ResultSet daten;

        try {
            Statement anweisung = v2.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
                    ResultSet.CONCUR_READ_ONLY);
            daten = anweisung.executeQuery("SELECT eloftwords.word"
                    + "FROM eloftwords "
                    + "WHERE word IN(SELECT eloftwords.word "
                    + "FROM eloftwords "
                    + "GROUP BY eloftwords.word "
                    + "HAVING count(word) > 1)");
            retWords.clear();
            while (daten.next()) {
                Datensatz = new Words(
                        daten.getString("word"));
                retDoppelteWoerter.add(Datensatz);
                System.out.println(Datensatz);
            }
        } catch (Exception ex) {
        }
        return retDoppelteWoerter;
    }

Dann mein Fenster mit der JArrayList:
Hier soll er mir nachdem er die Daten ausgelesen hat, die Worte die mehr als einmal vorkommen ausgeben: Das macht er nicht!Keine Fehlermeldung, garnichts:S
Die Methode ist unter dem Konstruktor meines Fensters
Java:
 public void DoppWoerter() {
        jListDopWoerter.setListData(db.retDoppelteWoerter.toArray());
    }

Hat Jemand einen PLan???:S
Danke
 
S

SlaterB

Gast
26. Thema in 30 Tagen und immer geht es um Words aus der DB, Doppelte filtern, Anzeigen in einer GUI, Listen, Update-Button usw.,
willst du nicht einfach ein Thema behalten und da immer deine Fragen stellen?
 

JonnieWalker

Bekanntes Mitglied
hmm ja vllt braucht das ja jemand mal deswegen stell ich das in die jeweils zugehörigen threads rein!

hmm ne er gibt mir jetzt immer noch das aus:
also die Methode sieht jetzt so aus:
Java:
    public ArrayList<Words> getDoppelteWoerter() {
        Words Datensatz;
        ResultSet daten;

        try {
            Statement anweisung = v2.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,
                    ResultSet.CONCUR_READ_ONLY);
            daten = anweisung.executeQuery("SELECT eloftwords.word "
                    + " FROM eloftwords "
                    + " WHERE word IN(SELECT eloftwords.word "
                    + " FROM eloftwords "
                    + " GROUP BY eloftwords.word "
                    + " HAVING count(word) > 1) ");
            retWords.clear();
            while (daten.next()) {
                Datensatz = new Words(
                        daten.getString("word"));
                retDoppelteWoerter.add(Datensatz);
                System.out.println(Datensatz);
            }
        } catch (Exception ex) {
            System.out.println(ex);
        }
        return retDoppelteWoerter;
    }

Fehler:
Java:
java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][SQL Server]Falsche Syntax in der N?he von 'ELOFTWORDS'.
 
S

SlaterB

Gast
übe erstmal
"SELECT eloftwords.word FROM eloftwords"
und wenn das nicht funktioniert schau dir an wie es in deinen früheren Threads oftmals doch lief
 

JonnieWalker

Bekanntes Mitglied
Er stört sich auf jeden fall ab dem Block
Java:
"WHERE word IN.... "
Hab nämlich ab diesem Teil auskommentiert um zu Testen und er macht alles.
Nur dieser Teil scheint fehlerhaft zu sein.
Immer noch:
Java:
[Microsoft][ODBC SQL Server Driver][SQL Server]Falsche Syntax in der N?he des 'SELECT'
Schl?sselwortes.

Kann man überhaupt Unterabfragen realiserien?
Bestimmt sonst würde das garkein Sinn machen:)
 

JonnieWalker

Bekanntes Mitglied
Leute ich hab echt keinen Plan!
Hab die Unterabfrage wie oben auskommentiert und die Klammer vergessen aber trotz allem
ohne Sie geht es aber es muss mit ihr gehen.
Ich werd mir das jetzt mal genau anschauen:rtfm:
 

Michael...

Top Contributor
Was soll bei der verschachtelten Abfrage rauskommen?

Welche Datenbank verwendest Du? Gibt's dazu keine JDBC Schnittstelle?

Habe schon lange nix mehr mit Datenbank zugriffen über ODBC gemacht, aber vielleicht kann ODBC nicht mit verschachtelten Statements umgehen?
Generell ist die JDBC Schnittsteller der ODBC zu bevorzugen.
 

JonnieWalker

Bekanntes Mitglied
Erstmal wird bei der Abfrage alle Worte aus der Tabelle "words" in die ArrayListe geholt.
Das funktioniert auch.
Bei der Methode von eben werden nur die Datensätze rausgeholt die mehr als einmal vorkommen.

Also ich hab das erste Fenster ne.
Die erste Abfrage der Methode getWords() die auch funktioniert, die liefert:
hallo
der
die
das
weshalb
hallo
das
das
hallo

Das zweite Fenster soll dann, dazu ist die Methode von hier gesacht, die Worte aus der Liste
holen die doppelt vorkommen:
also:
hallo
hallo
hallo
das
das
das

und dann hab ich noch einen Button im zweiten Fenster wo ich die Daten lösche.

Ich verwende die ODBC:JDBC:Schnittstelle.
 

Michael...

Top Contributor
Wie gesagt vielleicht hängt es ja mit ODBC zusammen - ist nur eine Vermutung

Nebenbei: In vielen Threads hier geht's darum mehrfach vorkommende Worte zu ermitteln und Duplikate zu löschen. Was hast Du eigentlich genau vor? Macht es überhaupt Sinn, dass Worte mehrfach in der Tabelle vorkommen (wie schaut die Tabellenstruktur in der DB aus?) oder ware es vielleicht nicht besser von vorne herein zu verhindern, dass Worte mehrfach in die DB geschrieben werden können?
 

JonnieWalker

Bekanntes Mitglied
Also die Datenbank Tabelle "words" hat -Spalten.
1.word
2.wordID

Ja es müssen unbedingt Wörter die öffters als einmal vorkommen angezeigt werden,
weil das Projekt auch das beinhalten soll, dass der User durch diesen Button "Doppelte Wörter anzeigen"
sehen kann dann in dem Fenster ah ok diese Worte wurden mal früher öffters eingefügt und müßen raus,
weil sie für die Volltextsuche kein sinn ergeben, also es soll in zukunft nicht mehr dannach gesucht werden.

Ich hatte das mal ohne Unterabfrage diese Methode die du gesehen Hast Michael, seitdem geht nichts mehr, vorher ging es.
Aber ich schau einfach bis morgen muss das Teil passen ob es will oder nicht.:)
 
M

maki

Gast
Wenn du MS SQL als DB Server verwendest, solltst du sowieso keine ODBC Krücke einsetzen (wie immer), ich empfehle den jTDS JDBC Treiber.
 

JonnieWalker

Bekanntes Mitglied
Muss ich den erst runterladen?
Oder gibt es den zum Anwählen bei den ODBC:Datenquellen einstellungen unter Windows>Systemsteuerung>Verwaltung?

Das könnte auch der Grund sein wieso er bei mehr als 300Daten aus der Datenbank so langsam ist!
Hmm.Denkst du das es am JDBC:ODBC liegt?
 
M

maki

Gast
Ich denke die JDBC:ODBC Brücke wird von den meisten Menschen missverstanden: Sie halten sie für etwas das man benutzten sollte ;)
Dem ist aber nicht so, sie war nie mehr als eine Demo als es noch keine JDBC Treiber gab und sollte auch nie Produktiv eingesetzt werden, steht auch so in der Doku :D

jTDS JDBC Driver
 

JonnieWalker

Bekanntes Mitglied
Guten morgen Leute,
also das Problem war in dem create.Statement().
Für alle die mit Unterabfragen arbeiten, benutzt nicht das "ResultSet.TYPE_SCROLL_INSENSITIVE,
ResultSet.CONCUR_READ_ONLY);".
Die "group by-Klausel" stört sich daran sehr.
Auch das Problem mit den 255.000 Datensätzen ist damit gelöst und das Programm ist super schnell.
Ich danke euch für euere Ideen und Anregungen.

Falls jemand mal sowas in der Art gebrauchen kann hier ist die funktionsfähige Methode
mit Unterabfrage.

Java:
    public ArrayList<Words> getDoppelteWoerter() {
        Words Datensatz;
        ResultSet daten;

        try {
            Statement anweisung = v2.createStatement();
            daten = anweisung.executeQuery("SELECT eloftwords.word FROM eloftwords " +
                                           "WHERE word IN" +
                                                "(SELECT eloftwords.word FROM eloftwords " +
                                                 "GROUP BY eloftwords.word " +
                                                 "HAVING COUNT(*) > 1) ");
            retDoppelteWoerter.clear();
            while (daten.next()) {
                Datensatz = new Words(
                        daten.getString("word"));
                retDoppelteWoerter.add(Datensatz);
            }
        } catch (SQLException ex) {
            System.out.println(ex);
        }
        return retDoppelteWoerter;
    }

Einen schönen Tag noch:)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Juelin Für Java-Spezialisten AWT, Swing, JavaFX & SWT 4
Juelin Java <-> Delphi AWT, Swing, JavaFX & SWT 3
H Exceptions seit java: 1.6.0_65 Umstellung AWT, Swing, JavaFX & SWT 3
H Exception: java.lang.ClassCastException AWT, Swing, JavaFX & SWT 2
M JavaFX java.lang.RuntimeException: Error initializing QuantumRenderer: no suitable pipeline found AWT, Swing, JavaFX & SWT 5
G Java GUI Dropdown-Menü anzeigen AWT, Swing, JavaFX & SWT 5
MJannek Eigene Java Klasse für allgemeine Grafikelemente AWT, Swing, JavaFX & SWT 8
thor_norsk Java - Allgemeine - Frage AWT, Swing, JavaFX & SWT 14
W Kennt jemand Dear ImGui (und den Java-Wrapper dazu)? AWT, Swing, JavaFX & SWT 0
B Java Projekt mit JavaFX und jfoenix ausführbar machen AWT, Swing, JavaFX & SWT 46
D JAVA Schieberegler AWT, Swing, JavaFX & SWT 6
N JavaFX Einfacher Taschenrechner mit Scene Builder und Java FX AWT, Swing, JavaFX & SWT 0
Jose05 Aus einer normalen Java Klasse eine FXML-Klasse laden AWT, Swing, JavaFX & SWT 12
S Welches Java Layout sollte ich verwenden? AWT, Swing, JavaFX & SWT 3
B Actionlistener mit Java Swing AWT, Swing, JavaFX & SWT 2
P Fehlermeldung: Error: Could not find or load main class set Caused by: java.lang.ClassNotFoundException: set AWT, Swing, JavaFX & SWT 5
Encera Java FX im Eclipse-Marketplace nichtmehr auffindbar AWT, Swing, JavaFX & SWT 6
G Versionscode aus build.gradle in Java-Klasse ausgeben lassen AWT, Swing, JavaFX & SWT 14
MJannek Java Dateien kopieren mit Fortschrittsbalken AWT, Swing, JavaFX & SWT 13
MJannek Frage zu Java Bundesligaverwaltung AWT, Swing, JavaFX & SWT 7
G Gibt es eine Möglichkeit, in Java alle möglichen Zeichen automatisch tippen zu lassen? AWT, Swing, JavaFX & SWT 13
E 3D-Grafik Java Fatal error bei LWJGL AWT, Swing, JavaFX & SWT 2
Heldderschatten Java Events und Interfaces AWT, Swing, JavaFX & SWT 18
volcanos Scrollen: JScrollPane mit Graphics g und Java-Fonts extends Frame ? AWT, Swing, JavaFX & SWT 5
sserio Java Fx - Problem AWT, Swing, JavaFX & SWT 3
U Warum wird zweimal die Affinetransformation estellt (2Dgraphics, Java)? AWT, Swing, JavaFX & SWT 31
U was bewirkt die methode fill und unterschied zu anderen fill Methoden in 2dgraphics? (Java)? AWT, Swing, JavaFX & SWT 6
DonBronson Java Graphics bewegbar machen (Drag&Drop) AWT, Swing, JavaFX & SWT 3
Yonnig Lokale HTML-Datei in Java GUI rendern AWT, Swing, JavaFX & SWT 4
E Java-TexturePaint sehr langsam AWT, Swing, JavaFX & SWT 9
N Java MySQL Datenbank durchsuchen? AWT, Swing, JavaFX & SWT 7
maximstein JavaFX WebView - java.lang.NoSuchMethodError: 'boolean com.sun.prism.ResourceFactory.isDisposed()' AWT, Swing, JavaFX & SWT 4
Splayfer Custom Font in AttributedString Java AWT, Swing, JavaFX & SWT 4
imawake Java Paket-Tracking Programm 📦 AWT, Swing, JavaFX & SWT 7
izoards *.doc Seitenränder per Java setzen... AWT, Swing, JavaFX & SWT 14
T FXML Datei in Java Code einbinden: javafx.fxml.LoadException AWT, Swing, JavaFX & SWT 2
J Key-Listener in Java AWT, Swing, JavaFX & SWT 37
J Java Datei durch CMD mit Parameter ausführen AWT, Swing, JavaFX & SWT 1
N Java Mouse Listiner macht alles zusammen AWT, Swing, JavaFX & SWT 4
J Java FX NullPointerException, ObservableList wird in View nicht angezeigt.. AWT, Swing, JavaFX & SWT 34
T Exception in thread "main" java.lang.NoClassDefFoundError AWT, Swing, JavaFX & SWT 4
M Error occurred during initialization of boot layer java.lang.module.FindException: Module javafx.controls not found AWT, Swing, JavaFX & SWT 14
AmsananKING Java Menü-Problem AWT, Swing, JavaFX & SWT 1
T Swing DPI-Skalierung und Java 2D unter Java 11 (und Windows 10) AWT, Swing, JavaFX & SWT 2
J Spiel mit Java AWT, Swing, JavaFX & SWT 9
I AWT java.awt.FileDialog - "coffee cup"-Icon lässt sich nicht ersetzen AWT, Swing, JavaFX & SWT 14
O Ein Java-Programm mit Swing steuern AWT, Swing, JavaFX & SWT 1
izoards Java FX Window Event SHOWING AWT, Swing, JavaFX & SWT 17
N FXMLLoader.load java.lang.RuntimeException: Gradle AWT, Swing, JavaFX & SWT 2
T Java GUI - Würfel Programm AWT, Swing, JavaFX & SWT 6
JojoSand Java Programm wird nicht gestartet - keinen Fehlerhinweis AWT, Swing, JavaFX & SWT 9
dtr84 JavaFX/OpenJFX mittels Apache Ivy einbinden (Java 11) AWT, Swing, JavaFX & SWT 18
M Jogl und Java 3d AWT, Swing, JavaFX & SWT 0
S0PEX JavaFX Java 8 auf 15 migrieren OpenJFX mit Gradle eingebunden, jedoch nicht gefunden !? AWT, Swing, JavaFX & SWT 4
I Gui in bestehendes Java-Programm AWT, Swing, JavaFX & SWT 11
V Java-Zeichenfeld mit AWT AWT, Swing, JavaFX & SWT 3
N java Gui friert scheinbar zufällig ein AWT, Swing, JavaFX & SWT 5
T Anderen Java Code durch Code kompilieren und Fehler in Label ausgeben AWT, Swing, JavaFX & SWT 5
P Java Fx einrichten AWT, Swing, JavaFX & SWT 2
pkm Frage wegen java.lang.IllegalStateException bei DocumentListener AWT, Swing, JavaFX & SWT 4
S JavaFX Java Custom Node Grafik zurückgeben AWT, Swing, JavaFX & SWT 2
MiMa Java und JavaFX 13 läuft endlich AWT, Swing, JavaFX & SWT 4
N eclipse Java, bilder benutzten Funktioniert nicht AWT, Swing, JavaFX & SWT 6
Trèfle Ausklappbare Diagramme in Java AWT, Swing, JavaFX & SWT 1
R Java, GUI, Hintergrundbild, Image, AWT, Swing, JavaFX & SWT 4
K JAVA FX Constraints AWT, Swing, JavaFX & SWT 2
F Java FX und webcam AWT, Swing, JavaFX & SWT 1
T Wie kann man in java aufwendige grafiken programmieren AWT, Swing, JavaFX & SWT 1
M Swing Java Swing/AWT Combobox Bug AWT, Swing, JavaFX & SWT 3
S Java GUI durch variable Größe einer Map anpassen AWT, Swing, JavaFX & SWT 3
J Java SWT Tabelleninhalt formattieren AWT, Swing, JavaFX & SWT 10
Blender3D Falsche Werte mit Java Toolkit Screensize AWT, Swing, JavaFX & SWT 4
K Swing AWT-EventQueue-1 java.lang.NoClassDefFoundError bei setVisible(true) AWT, Swing, JavaFX & SWT 3
A Java Programm gestalten AWT, Swing, JavaFX & SWT 4
B [Problem] Java öffnet Word-Datein nicht AWT, Swing, JavaFX & SWT 14
S Swing Java Swing AWT, Swing, JavaFX & SWT 6
I Java Bildfarbe ändern wie bei Photoshop AWT, Swing, JavaFX & SWT 9
R JavaFX Java FXML Vererbung in Klassen AWT, Swing, JavaFX & SWT 9
T Java: Zwei abhängige JSlider machen nicht das, was sie sollen AWT, Swing, JavaFX & SWT 4
J Parallele Aktionen in Java FX richtig durchführen. AWT, Swing, JavaFX & SWT 5
Neumi5694 java.awt.Window nach javafx.stage.Window AWT, Swing, JavaFX & SWT 1
M JavaFX java.lang.IllegalStateException: Location is not set. AWT, Swing, JavaFX & SWT 9
L Java- CardLayout AWT, Swing, JavaFX & SWT 10
M Java zeichnet nicht pixelgenau AWT, Swing, JavaFX & SWT 40
B Swing Eclipse is running under 0, but this Java project has a 1.6 Java compliance level, so WindowBuilder AWT, Swing, JavaFX & SWT 2
L Java- UI zweites Fenster aus einer anderen Klasse öffnen durch ButtonClick AWT, Swing, JavaFX & SWT 4
S Java Gui AWT, Swing, JavaFX & SWT 5
R Sierpinski Dreieck mit Java FX AWT, Swing, JavaFX & SWT 4
Flynn java.lang.UnsupportedOperationException: Not supported yet AWT, Swing, JavaFX & SWT 7
D Zwei getrennte Java Klassen verbinden. Wie ? AWT, Swing, JavaFX & SWT 2
D SQL Statements mit Java Swing benutzen AWT, Swing, JavaFX & SWT 4
D DatePicker für Java Swing AWT, Swing, JavaFX & SWT 2
S AWT Java print dialog Problem AWT, Swing, JavaFX & SWT 0
N Aktualisierung des Fensters AWT Java ohne Ruckeln AWT, Swing, JavaFX & SWT 3
MiMa Java, Maven Projekte nach JavaFX? AWT, Swing, JavaFX & SWT 3
T Java Swing - kleines Rechteck unter dem cursor AWT, Swing, JavaFX & SWT 5
L java.lang.NullPointerException - Fehlermeldung AWT, Swing, JavaFX & SWT 2
D Swing Java JComboBox Example AWT, Swing, JavaFX & SWT 16
J AWT System Farben / java.awt.SystemColor funktioniert nicht AWT, Swing, JavaFX & SWT 4
MiMa Java Projekt nach JavaFX convertieren AWT, Swing, JavaFX & SWT 4

Ähnliche Java Themen


Oben