Java JDBC MySQL Query

JadeNinja

Mitglied
Servus leute,
hab da ma ne frage zu meinem quellcode:
Java:
    public static void userid(){

        try{
            a = con.createStatement();

            // Service Provider Object instanzieren
            SERVICE_PROVIDER serviceProvider = new SERVICE_PROVIDER();
            serviceProvider.id=srvprovider;
            Statement groupQuery = con.createStatement();
            //Liste mit allen Gruppen innerhalb des Service Providers holen
            ResultSet groupListRS = groupQuery.executeQuery("SELECT DISTINCT `GROUP` FROM cdr_processed WHERE SERVICE_PROVIDER = '"+srvprovider+"' ORDER BY `GROUP`");

            //Durch alle Gruppen iterieren
            while(groupListRS.next()) {

                String groupId = groupListRS.getString("GROUP");

                //Object für die Gruppe erstellen
                GROUP group = new GROUP();

                //ID der aktuellen Gruppe setzen
                group.id = groupId;

                //Die Gruppe an die Liste mit Gruppen innerhalb des Service Providers anhängen
                serviceProvider.GROUP.add(group);

                Statement userQuery = con.createStatement();
                //Liste mit allen user innerhalb der Gruppen holen
                ResultSet userListRS = userQuery.executeQuery("SELECT DISTINCT USER_ID FROM cdr_processed WHERE `GROUP` = '"+groupId+"' ORDER BY USER_ID");

                //Durch alle Gruppen iterieren
                while(userListRS.next()) {

                    String userId = userListRS.getString("USER_ID");

                    //Object für den User erstellen
                    USER user = new USER();

                    //ID des aktuellen Users setzen
                    user.id = userId;

                    //Den User an das User Array innerhalb der Gruppe anhängen
                    group.USER.add(user);

                    //Liste aller CDRs des Users holen
                    ResultSet rsstart = a.executeQuery("SELECT SERVICE_PROVIDER, `GROUP`, DIRECTION, LOCAL_NUMBER, RESPONSIBLE_NUMBER, REMOTE_LOCATION, CALL_TYPE, START_TIME, END_TIME, USER_ID, DURATION, PRICE, USER_TIME_ZONE FROM cdr_processed WHERE USER_ID = '"+userId+"' ORDER BY START_TIME");

                    //Durch alle CDRs iterieren
                    while(rsstart.next()){

                        //CDR Objekt instanzieren
                        CDR cdr = new CDR();

                        user.CDR.add(cdr);

                        cdr.provider = rsstart.getString("SERVICE_PROVIDER");
                        cdr.callType = rsstart.getString("CALL_TYPE");
                        cdr.direction = rsstart.getString("DIRECTION");
                        cdr.duration = rsstart.getString("DURATION");
                        cdr.localNumber = rsstart.getString("LOCAL_NUMBER");
                        cdr.remoteNumber = rsstart.getString("RESPONSIBLE_NUMBER");
                        cdr.remoteLocation = rsstart.getString("REMOTE_LOCATION");
                        cdr.group = rsstart.getString("GROUP");
                        cdr.user = rsstart.getString("USER_ID");
                        cdr.price = rsstart.getString("PRICE");

                        String timezone = rsstart.getString("USER_TIME_ZONE");
                        timezone = !timezone.startsWith("-") ? "+" + timezone : timezone;
                        TimeZone timeZone = TimeZone.getTimeZone("GMT" + timezone);

                        sdf.setTimeZone(timeZone);

                        long start = rsstart.getLong("START_TIME");
                        long end = rsstart.getLong("END_TIME");

                        //Formatierte Zeiten im Objekt speichern
                        cdr.startTime = sdf.format(new Date(start));
                        cdr.endTime = sdf.format(new Date(end));

                    }

                }

            }
            XML.writeFile(serviceProvider);//nach ca 1h wird dieser punkt erreicht....
            System.out.println();
            System.out.println("File successfully written!");
             }catch (SQLException e) {
                System.err.println("Exception: " + e.getMessage());
                System.err.println("SQLState: " + e.getSQLState());
                System.err.println("VendorError: " + e.getErrorCode());
                e.printStackTrace();
            }


    }
Mein Problem dazu ist ganz einfach, es dauert EWIG! Meine Datenbank hat 1.5 Millionen einträge, von dem jeder 15 spalten besitzt. Wenn ich jetzt diese Methode aufrufe, brauch das Programm ca. 1h um mir eine XML Datei auszugeben. Hab schon versucht die Datenbank zu Indizieren, aber da dauernd neue Einträge hinzukommen ist das auf dauer keine Lösung. Gibts da vielleicht irgend einen Kniff, oder hab ich vielleicht sogar einen Fehler drinn? Bin auch alles mal mit dem Debugger durchgegangen, also von den Daten her stimmt alles, nur leider dauert der ganze spaß halt echt ewig...
Wär cool wenn mir jemand helfen könnte =)
Mfg
 

homer65

Top Contributor
Was genau dauert denn ewig? In deinem Quelltext sind drei Abfragen drin.
Und dein Gegenargument gegen Indizes verstehe ich ehrlich gesagt nicht.
 
G

Gast2

Gast
Ohne Indexes kein Wunder.

Wenn dir das einspielen eines Indexes zu lange dauert guck mal ob du die (je nach verwendeten RDMBS unterschiedlich) im Hintergrund aufbauen lassen kannst.

Wenn der Index einmal aufgebaut ist, dann ist es kein Problem wenn in der Tabelle neue Einträge hinzukommen. Die werden dann auch in den Index aufgenommen.
 

JadeNinja

Mitglied
Also direkt gegen Indexes habe ich ja nichts, nur dauert mir das wie gesagt einfach zu lange!
Ja ich schau mal ob das machbar ist, den ganzen Spaß im hintergrung laufen zu lassen, aber die abfrage die am längsten dauert ist die 2. Query, was ich ganz einfach nicht verstehe. Also ich mein, sie ist nicht die längste, hat keine besonderen felder, die 3. müsste doch rein von der logik her am längsten dauern da sie ja die meisten daten abfragt?
naja wenn sich am quellcode nichts ändern lässt versuch ichs halt über index...
Mfg
 
G

Gast2

Gast
Also direkt gegen Indexes habe ich ja nichts, nur dauert mir das wie gesagt einfach zu lange!

Isst du eine Pizza auch kalt weil es zu lange dauert den Backofen anzuwerfen oder gehst lieber zu Fuß weil es zu lange dauert das Auto vollzutanken?

Wenn du mit 1.5 Millionen Datensätzen keine Indexe verwendest darfst du dich über schlechte Datenbankperformance nicht wundern. Du musst dir ja nur einmal überlegen was das RDMBS machen muss wenn du eine Anfrage stellst. Ohne Index muss jede Zeile einmal gelesen werden.
 

JadeNinja

Mitglied
Hm, okay ich habe jetzt einfach 12h lang indizes gesetzt und jetzt läuft das ganz flott durch, hätte gedacht man könnte evtl. etwas am quellcode optimieren aber okay, trotzdem danke
mfg
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
A Java - JDBC SQL Java Basics - Anfänger-Themen 2
Vince42 Java 8 JDBC / OLE DB Java Basics - Anfänger-Themen 15
B Java Datenbankverbindungsfähigkeit - JDBC Java Basics - Anfänger-Themen 1
G welche Java-Technologie für JDBC geeignet Java Basics - Anfänger-Themen 6
D JDBC Treiber unter dem Java Application Server Java Basics - Anfänger-Themen 6
J java und jdbc mit access Java Basics - Anfänger-Themen 3
D Einige Fragen zu Java Java2D JDBC usw. XD Java Basics - Anfänger-Themen 13
O Java Kara geschweifte Klammern Java Basics - Anfänger-Themen 2
richis-fragen Mausrad logitech kann links und rechts klick wie in java abragen. Java Basics - Anfänger-Themen 15
XWing Java Klssenproblem Java Basics - Anfänger-Themen 4
R Umgebungsvariable java -cp gibt immer Java-Hilfe... Java Basics - Anfänger-Themen 3
farbenlos Csv Datei in Java einlesen Java Basics - Anfänger-Themen 18
F TableModelListener: java.lang.ArrayIndexOutOfBoundsException: 132 Java Basics - Anfänger-Themen 3
G Java 8 - Support-Ende Java Basics - Anfänger-Themen 7
T Java Weihnachtsbaum + Rahmen Java Basics - Anfänger-Themen 1
N Will mit Java anfangen Java Basics - Anfänger-Themen 13
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
M Java Iterator Verständnisfrage Java Basics - Anfänger-Themen 6
M Java Mail Programm Java Basics - Anfänger-Themen 4
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
JaZuDemNo Java im Studium Java Basics - Anfänger-Themen 7
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
I QR code in Java selber generieren Java Basics - Anfänger-Themen 5
V Java-Ausnahmebehandlung: Behandlung geprüfter Ausnahmen Java Basics - Anfänger-Themen 1
krgewb Java Streams Java Basics - Anfänger-Themen 10
A Überwältigt von der komplexen Java Welt Java Basics - Anfänger-Themen 29
O Mehrfachvererbung auf Spezifikations- und Implementierungsebene in Java. Interfaces Java Basics - Anfänger-Themen 19
John_Sace Homogene Realisierung von Generics in Java ? Java Basics - Anfänger-Themen 19
P Meldung aus Java-Klasse in Thread an aufrufende Klasse Java Basics - Anfänger-Themen 1
R mit Java API arbeiten Java Basics - Anfänger-Themen 9
P JDK installieren Probleme bei der Java-Installation Java Basics - Anfänger-Themen 8
S Java: Wie sortiere ich eine ArrayList benutzerdefinierter Objekte nach einem bestimmten Attribut? Java Basics - Anfänger-Themen 2
Timo12345 JNLP File mit Java öffnen Java Basics - Anfänger-Themen 2
S Video Editierung mit Java.._ Java Basics - Anfänger-Themen 2
F Einstelungen in Java - CursorBlinkRate Java Basics - Anfänger-Themen 10
A PHP $_POST["name"] in Java Java Basics - Anfänger-Themen 3
vivansai21 Is there a oneliner to create a SortedSet filled with one or multiple elements in Java? Java Basics - Anfänger-Themen 9
Athro-Hiro Weißes Bild in Java erstellen Java Basics - Anfänger-Themen 3
Arjunreddy Can someone please tell me how to use a debugger in BlueJ(a Java environment) Java Basics - Anfänger-Themen 1
M Java assoziationen (UML) Java Basics - Anfänger-Themen 8
H Excel-Tabellen mit Java erstellen Java Basics - Anfänger-Themen 4
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
H Nutzt Eclipse alle CPU-Threads beim Ausführen von Java-Programmen? Java Basics - Anfänger-Themen 4
xXGrowGuruXx Java einstieg, leichte sache 0 verstanden Java Basics - Anfänger-Themen 7
A java.sql.SQLException: Data type mismatch. Java Basics - Anfänger-Themen 1
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
N Java Spiel Figur auf dem Hintergrundbild bewegen. Java Basics - Anfänger-Themen 11
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
N Java Taschenrechner hat Jemand vlt einen Tipp dafür wie ich jetzt die buttons verbinden kann und das Ergebnis auf dem textfield anzeigen lassen kann Java Basics - Anfänger-Themen 13
A Lerngruppe Java Java Basics - Anfänger-Themen 2
G Help me in the Java Program Java Basics - Anfänger-Themen 2
L Java- Vererbung Java Basics - Anfänger-Themen 4
LimDul Suche Java Stream Tutorial Java Basics - Anfänger-Themen 2
_so_far_away_ Ich möchte Java lernen Java Basics - Anfänger-Themen 11
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
V Bild per Java Script austauschen Java Basics - Anfänger-Themen 7
MoxMorris this Keyword in Java Java Basics - Anfänger-Themen 14
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
wolei JAVA Zeitdifferenz feststellen. Java Basics - Anfänger-Themen 4
DiyarcanZeren Rekursion in Java Java Basics - Anfänger-Themen 5
wolei Java generic interface in a generic class Java Basics - Anfänger-Themen 6
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Circle.java:5: error: <identifier> expected Java Basics - Anfänger-Themen 2
julian-fr Wie kann ich am besten Java lernen? Java Basics - Anfänger-Themen 17
A Java-Properties und -RessourceBundles Java Basics - Anfänger-Themen 5
lrnz22 Java-Basics-Aufgabe Java Basics - Anfänger-Themen 8
R Java kann nicht installiert werden Java Basics - Anfänger-Themen 8
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
G In ein java Dokument Ton einbinden Java Basics - Anfänger-Themen 1
C was heisst es wenn java ']' erwartet ? Java Basics - Anfänger-Themen 2
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
KeinJavaFreak Erste Schritte Java "Executable Jar File" nicht vorhanden Java Basics - Anfänger-Themen 1
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
J Java Testklasse Java Basics - Anfänger-Themen 5
P Java Selenium . Parameterized.Parameters erzeugt eine Fehlermeldung Java Basics - Anfänger-Themen 14
W Java-Code mit Array Java Basics - Anfänger-Themen 14
W Java-Code Java Basics - Anfänger-Themen 2
P BeforeEach AfterEach werden nicht ausgeführt. Java / Selenium Java Basics - Anfänger-Themen 4
A Wie führe ich eine Batch-Datei von meiner Java-Anwendung aus? Java Basics - Anfänger-Themen 18
W Java code- TicTac toe Java Basics - Anfänger-Themen 51
Ostkreuz Java Docs Java Basics - Anfänger-Themen 9
R Java boolean Unterschied " == " und " = " Java Basics - Anfänger-Themen 3
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
W Java-code Java Basics - Anfänger-Themen 8
W Java-code Java Basics - Anfänger-Themen 9
W Java-Code erklären Java Basics - Anfänger-Themen 6
A Java Kurs / Tutorial Java Basics - Anfänger-Themen 6
K Java Lotto Spiel; ich komme nicht weiter Java Basics - Anfänger-Themen 15
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
P Java 2n Potenzieren Java Basics - Anfänger-Themen 1
J Java Hamster Java Basics - Anfänger-Themen 4
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
V Die Funktion des neuen Schlüsselworts in Java Java Basics - Anfänger-Themen 1
W Junit-Test (Java) Java Basics - Anfänger-Themen 4
W Testfälle bei Java ( Junit-Test) Java Basics - Anfänger-Themen 3
laxla123 If-else Java Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben