java optimieren. wie daten schneller in mysqlDB schreiben?

Status
Nicht offen für weitere Antworten.

gondor

Bekanntes Mitglied
hallo java-freunde!

ich habe ein problem beim einlesen großer textdateien.

und zwar werden einzelne werte in eine db (mySQL) geschrieben:

das textfile hat folgende struktur:

[..]
2004-12-12 13:01:12 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
2004-12-12 13:01:13 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
2004-12-12 13:01:14 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
2004-12-12 13:01:15 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
2004-12-12 13:01:16 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
2004-12-12 13:01:17 1.000000 2.000000 3.000000 4.000000 5.000000 6.000000 7.000000 8.000000
[..]

das einlesen mit meinem java-programm dauert alleine schon bei ca. 100 zeilen á 8 spalten um die
20 sekunden. da eine datei rund 500.000 zeilen beinhalten kann, würde das stunden brauchen, was
deutlich zu lange ist. der ablauf ist folgend: eine zeile wird eingelesen und jeder einzelne wert
in mysql eingeschrieben bzw. die querie dafür in einen vector gespeichert. das zusammenstellen und
einlesen geschieht hier:

diese methode wird von einem thread gestartet, der mir die werte in die db schreibt:

Code:
private boolean parseData_DateTime(C_ImportFile import_file_, int recordID_) {

        System.out.println("C_Import --> parseData_DateTime");

        String datetime = "0000-00-00 00:00:00";

        /*Error-Flag*/
        boolean error_parse = true;

        int progress_counter = 0;

        /*Sensoren*/
        List sensors = null;

        /*Sensor-Zeile*/
        String buffer = null;

        /*File wird gepuffert eingelesen*/
        BufferedReader br = null;

        Vector query_update = new Vector();

        try {

            br = new BufferedReader(new FileReader(import_file_.getAbsolutePath()));

            /*Sensoren*/
            sensors = new Vector();

            while ((buffer = br.readLine()) != null && !this.interrupted) {

                this.setValue(progress_counter++);

                if (buffer.matches("Zeit \\[.*?")) {

                    /*Header mit Sensoren einlesen*/
                    sensors = this.parseHeader(buffer);

                } else if (!sensors.isEmpty()) {

                    String[] tokens = buffer.split(this.seperator_property);

                    for (int i = 0; i < tokens.length; i++) {

                        SensorHeader header = ((SensorHeader) sensors.get(i));

                        int sensorID = measurement_sensor.getSensorID(header.getName(), header.getType().getId());

                        if (header.getType().getId() == C_HeaderConstant.UNIT_TIME_ID) {
                            datetime = tokens[i];
                        } else {
                            String command = "INSERT INTO " + C_SensorValueTable.TableName + " (" + C_SensorValueTable.SensorValueSensorID + ", " + 
C_SensorValueTable.SensorValueRecordID + ", " + C_SensorValueTable.SensorValueMeasurementTime + ", " + C_SensorValueTable.SensorValue + ") VALUES (" + sensorID + ", " 
+ recordID_ + ", '" + datetime + "', " + Double.parseDouble(tokens[i]) + ");";
                            query_update.add(command);
                        }
                    }
                }
            }

            query_sensor_value.queryUpdate(query_update);

        } catch (Exception ex) {
            /*** Errorhandling ***********************************/
            System.out.println("Error: parseData_DateTime (Exception)");
            cat.error("Error: parseData_DateTime (Exception)");

            error_parse = false;
        }

        return error_parse;
    }

die einzelnen queries werden von mir in einen vector gespeichert und an query_update geschickt:

Code:
public void queryUpdate(Vector queries_) {

        Vector queries = queries_;

        Statement st = null;

        this.openConnection();

        String command = null;

        try {

            Iterator it = queries.iterator();

            while (it.hasNext()) {

                st = this.mySQL_connection.createStatement();
                st.addBatch(it.next().toString());
                st.executeBatch();
            }

        } catch (SQLException ex) {
            /*** Errorhandling ***********************************/
            System.out.println("Error: queryUpdate (SQLException)");
            cat.error("Error: queryUpdate (SQLException)");
        }

        this.closeConnection();

}

auch die verwendung von prepare statements brachte keinen wirklichen fortschritt.

wie kann ich meinen java-code optimieren, damit meine daten wesentlich 'schneller'
in die db geschrieben werden können. laut mySQL gibt es den befehl LOAD DATA INFILE,
der ein ganzes File innerhalb von sekunden in eine tabelle einlesen kann. könnte ich
damit evtl. weiterkommen?

wäre hier sehr auf hilfe angewiesen und würde mich freuen, wenn mir ein guter tipp
zum weiterentwickeln gegeben wird.

herzlichen dank,

gondor(..)

edited by thE_29: auch hier abgeteilt
 

Wildcard

Top Contributor
Vermutlich bricht dir das '+' das Genick!
Wo immer es geht nicht mit String, sondern mit StringBuffer arbeiten, besonders bei diesen Datenmengen.
Am besten man gewöhnt sich String + String komplett ab und vergisst das dieser Operator jemals überladen wurde :wink:
 

gondor

Bekanntes Mitglied
@wildcard

danke für deine schnelle hilfe.

du meinst bestimmt diese stelle:
Code:
String command = "INSERT INTO " + C_SensorValueTable.TableName + " (" + C_SensorValueTable.SensorValueSensorID + ", " + 
C_SensorValueTable.SensorValueRecordID + ", " + C_SensorValueTable.SensorValueMeasurementTime + ", " + C_SensorValueTable.SensorValue + ") VALUES (" + sensorID + ", " 
+ recordID_ + ", '" + datetime + "', " + Double.parseDouble(tokens[i]) + ");";

wie sollten denn meine arbeiten in bezug auf dem 'StringBuffer' fortgesetzt werden?

kannst du ein kleines beispiel angeben? wäre sehr nett ;)

gondor(..)


edited by thE_29: abgeteilt - zu störend
 

Wildcard

Top Contributor
String sind unveränderlich, das heißt immer wenn du etwas mit einem String machst (was anhängen, was rausschneiden, was ändern...)
erzeugst du ein neues Objekt. Um das zu vermeiden solltest du mit StringBuffer arbeiten. Statt dem '+' dann eben:
Code:
StringBuffer buffer = new StringBuffer("blupp");
buffer.append("bla");
Der Performanceunterschied ist heftig. Siehe hierzu:
http://www.java-forum.org/de/viewtopic.php?t=15006
 

gondor

Bekanntes Mitglied
@wildcard

... ja das ist wirklich 'krass'. wenn es daran liegen sollte, bis du mein heutiger held ;)

der aufbau meiner query sollte dann so aussehen, oder?

Code:
        StringBuffer buffer = new StringBuffer("INSERT INTO "); 
        buffer.append(C_SensorValueTable.TableName);
        buffer.append(" (");
        buffer.append(C_SensorValueTable.SensorValueSensorID);
        buffer.append(" ,");
        buffer.append(C_SensorValueTable.SensorValueRecordID);
        buffer.append(" ,");
        buffer.append(C_SensorValueTable.SensorValueMeasurementTime);
        buffer.append(" ,");
        buffer.append(C_SensorValueTable.SensorValue);
        buffer.append(") VALUES (");
        ...

prüfe das mal gleich.

gondor(..)
 

Wildcard

Top Contributor
gondor hat gesagt.:
der aufbau meiner query sollte dann so aussehen, oder?
So hatte ich mir das gedacht :D
Der Vector ist uU auch keine so gute Wahl, da er synchronized ist. Wenn man das nicht braucht sollte man auch nicht
unbedingt Vector benutzen. Dann lieber ArrayList. Wird hier aber weniger das Problem sein denke ich...
 

gondor

Bekanntes Mitglied
@wildcard

also, das ist schon schneller geworden. das die gute nachricht.

die schlecht, nicht bedeutend 'viel' schneller. 150 zeilen á 8 werte ca. 15 sek. kann es evtl. auch daran liegen, das die berechnung aus einem parallel gestarteten thread geschieht? diesen habe ich extra schon die prio (9) gegeben.

an der performance kann es eigentlich auch nicht liegen (2GHz, 756ram) wo ist da der bottleneck? oder ist java eh nicht so schnell, auf datenstrukturebene?

please help :(

gondor(..)
 

gondor

Bekanntes Mitglied
@DP

ja, java ist langsam. langsamer als andere programmiersprachen und schneller als andere programmiersprachen... ;)

akkustikkoppler? hä? was´n das...

hier mal die openConnection:

Code:
     /**
     * Stellt Verbindung zur DB her
     */
    protected void openConnection() {

        //System.out.println("C_DBQuery --> openConnection");

        try {
            /*Treiber laden*/
            Class.forName(C_DB.MySQL_DRIVER).newInstance();
            /* Verbindung aufnehmen*/
            this.mySQL_connection = DriverManager.getConnection(this.mySQL_connection_string, this.mySQL_user, this.mySQL_passwd);

        } catch (Exception ex) {
            /*** Errorhandling ***********************************/
            System.out.println("Error: openConnection (Exception)");
            //cat.error("Error: openConnection (Exception)");
            System.out.println("Exception: " + ex.getMessage());
            System.out.println("ExceptionState: " + ex.toString());
            System.out.println("VendorError: " + ex.getLocalizedMessage());
        }
    }

sieht für mich ganz 'normal' aus... und systemausgaben habe ich auch keine ???:L

gondor(..)
 

gondor

Bekanntes Mitglied
komisch ist auch, wenn ein großes file (naja groß? 5000 zeilen) eingelesen wird, kommt es meistens zu einer exception, mit der ich nicht so wirklich etwas anfangen kann:

Code:
Error: openConnection (Exception)
Exception: Unable to connect to any hosts due to exception: java.net.BindException: Address already in use: connect
** BEGIN NESTED EXCEPTION ** 
java.net.BindException
MESSAGE: Address already in use: connect
STACKTRACE:
java.net.BindException: Address already in use: connect
	at java.net.PlainSocketImpl.socketConnect(Native Method)
	at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:305)
	at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:171)
	at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:158)
	at java.net.Socket.connect(Socket.java:452)
	at java.net.Socket.connect(Socket.java:402)
	at java.net.Socket.<init>(Socket.java:309)
	at java.net.Socket.<init>(Socket.java:124)
	at com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:121)
	at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:220)
	at com.mysql.jdbc.Connection.createNewIO(Connection.java:1768)
	at com.mysql.jdbc.Connection.<init>(Connection.java:440)
	at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:400)
	at java.sql.DriverManager.getConnection(DriverManager.java:512)
	at java.sql.DriverManager.getConnection(DriverManager.java:171)
	at de.airbus.arctic.db.mysql.C_DBQuery.openConnection(C_DBQuery.java:160)
	at de.airbus.arctic.db.mysql.C_DBQuerySensor.getSensorID(C_DBQuerySensor.java:498)
	at de.airbus.arctic.measurement.sensor.C_Sensor.getSensorID(C_Sensor.java:95)
	at de.airbus.arctic.measurement.importDB.C_Import.parseData_DateTime(C_Import.java:505)
	at de.airbus.arctic.measurement.importDB.C_Import.run(C_Import.java:371)
	at de.airbus.arctic.gui.dialog.status.C_Dialog_Import.run(C_Dialog_Import.java:693)
	at java.lang.Thread.run(Thread.java:534)
** END NESTED EXCEPTION **

und komisch ist, dass mir in der methode queryUpdate

Code:
while (it.hasNext()) {

                st = this.mySQL_connection.createStatement();
                System.out.println(it.next().toString());
                st.addBatch(it.next().toString());
            }

            int[] execute_batch = st.executeBatch();
            System.out.println("Anzahl Batch-Updates : " + execute_batch.length + "");

bei executeBatch mir eine '1' rausgibt, obwohl er z.B. 100mal addBatch(string) gemacht hat. richtig wäre doch da '100'.

der string sieht folgendermaßen aus:

Code:
INSERT INTO mess_sensor_value (sensor_value_sensor_id, sensor_value_record_id, sensor_value_time, sensor_value_value) VALUES ( 43, 33, '2004-12-12 13:01:03', 15.0 )

warum macht der das?

hm...

gondor(..)
 

thE_29

Top Contributor
Achja und wenn du alle Spalten in der richtigen Reihenfolge befühlst, kannst du dir das sparen, das du vorher alle Spalten angibst!

Bsp.: INSERT INTO mess_sensor_value VALUES( 43, 33, '2004-12-12 13:01:03', 15.0 )
 

thE_29

Top Contributor
Das war als Bsp!

Du mußt bei diesem Insert alle SPALTEN befühlen, also wenn du mehr Spalten hast und dort null Werte normalerweise stehen würden, müßtest du dann hinten ,null,null, ... etc reinschreiben!
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H .java Dateien in Eclipse einbinden und ausführen Java Basics - Anfänger-Themen 1
onlyxlia Schlüsselworte Was meint man mit "einen Typ" in Java erstellen? Java Basics - Anfänger-Themen 2
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
RashAGhul Java Verwaltungstool Erstellen mit kaum Wissen Java Basics - Anfänger-Themen 9
S Substring in java Java Basics - Anfänger-Themen 3
Z Operatoren Java Applikation Java Basics - Anfänger-Themen 8
Tw1Z Erste Schritte Sort in java Java Basics - Anfänger-Themen 2
sasnitzer java augensumme von zwei würfeln ist 1 Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben