newit1
Goto Top

LOAD DATA LOCAL INFILE . INTO TABLE

Hallo,


ich importiere mit diesem Behfel eine CSV-Datei mit Daten in eine Tabelle von PHPmyAdmin:


LOAD DATA LOCAL INFILE \" /home/myuser/Schreibtisch/Datei.csv\" INTO TABLE xxxx CHARACTER SET 'utf8' FIELDS TERMINATED BY ';'  


Die CSV Datei hat folgenden Aufbau:

1;Müller;Max;789


Tabllenstruktur in PhpmyAdmin:

unbenannt


Ich will nun erreichen, dass der Befehl nicht ausgeführt wird, wenn z.B. im Feld "tel_ID" etwas anderes als eine Zahl steht, sprich bei "INSERT" Fehlern soll abgebrochen werden.

Wie erreiche ich das?


Gruß und Vielen Dank!

Content-ID: 362749

Url: https://administrator.de/forum/load-data-local-infile-into-table-362749.html

Ausgedruckt am: 15.01.2025 um 05:01 Uhr

Voiper
Voiper 29.01.2018 um 16:03:08 Uhr
Goto Top
Du musst deine Probleme nicht zweimal Posten...

Bei INSERT Fehler abbrechen
Arano
Arano 29.01.2018 um 16:08:35 Uhr
Goto Top
Moin.

Hallo ? Bei INSERT Fehler abbrechen
Der ist gerade mal 18h alt (abzüglich SONNTAGSzeit...)

...immer noch stehts im Handbuch: MySQL-Reference 13.2.6 LOAD DATA INFILE Syntax

Zitat weggelassen, weil steht ja eh im Link


~Arano
newit1
newit1 29.01.2018 aktualisiert um 16:19:33 Uhr
Goto Top
Hi @Arano

finds echt nett das du dich um mein Problem kümmerst aber ich habe diese Seite selbst heute mehrmals besuch und gelesen....
Alles was ich daraus ableiten kann ist jedoch nur, dass ich mit dem IGNORE Befehl die Fehler überspringe.... ich will ja exakt das Gegenteil.

Sorry bin auch kein MQSQL Fuchs...
Arano
Arano 29.01.2018 um 16:39:08 Uhr
Goto Top
Na,

finds echt nett das du dich um mein Problem kümmerst
Na wie gesagt, helfen tun wir ja gerne.

LOCAL also affects error handling:
  • With LOAD DATA INFILE, data-interpretation and duplicate-key errors terminate the operation.
  • With LOAD DATA LOCAL INFILE, data-interpretation and duplicate-key errors become warnings and the operation continues because the server has no way to stop transmission of the file in the middle of the operation. For duplicate-key errors, this is the same as if IGNORE is specified. IGNORE is explained further later in this section.

Da du in den anderen Fragestellungen immer mal selbiges aus einer Bash-Datei herraus machst, nehme ich mal an das du lokal auf deinem Rechner arbeitest ?
Wenn das so ist, solltest du das LOCAL in deinem Statement auch weglassen können. Damit sollte die Fehlerbehandlung wieder möglich sein.
Warum und weiso ...steht in der Reference die verlinkt wurde. ;)

Zugegeben ich mach das auch nicht immer, aber man sollte sich mit den Befehlen und Kommandos die man so verwendet schon auseinander setzen/einlesen. Denn blindes vertrauen/probieren kann auch mal im totalen Datenverlust enden.


~Arano
SlainteMhath
SlainteMhath 29.01.2018 um 16:46:48 Uhr
Goto Top
Moin,

also wenn tel_id tatsächlich als PRIMARY und (logischerweise ) mit NOT NULL definiert ist, dann glaub ich nicht das mysql hier eine Zeile importiert und das Feld leer lässt - sowie das in deinem anderen Post behauptet wird.

Was man aber machen kann: (Pseudocode, da ich den mysql Syntax nicht genau kenne)

1. Import in Temp-Tabelle die in der Struktur der orginal Tabelle gleicht, in der aber alle Felder NULL sein können.
2. Transaktion starten
3. INSERT INTO original Tabelle SELECT FROM Temp-Tabelle
4. Bei Fehler -> Rollback
5. Kein Fehler -> Commit

lg,
Slainte
newit1
newit1 29.01.2018 um 16:53:42 Uhr
Goto Top
Okay, verstanden!

Problem ist jetzt nur, bekomme bei Ausführung die Fehlermeldung:

The MYSQL Server is running with the --secure-file-priv option so it cannot execute this statement


Aber das ist ja wieder ein anders Problem. Trotzdem danke ich dir!
Arano
Arano 29.01.2018 um 18:33:42 Uhr
Goto Top
Na,

also wenn tel_id tatsächlich als PRIMARY und (logischerweise ) mit NOT NULL definiert ist, dann glaub ich nicht das mysql hier eine Zeile importiert und das Feld leer lässt - sowie das in deinem anderen Post behauptet wird.
Ging mir auch schon durch den Kopf das es doch krachen müsste oder es irgendeine Art Typen-Cast gibt.
...lass es uns doch mal probieren:

mysql> create temporary table newit (id int, vname char(30), primary key (id));
mysql> insert into newit value( 1, 'hallo'),(2,'wer');  

[17:58]arano:~$ cat newit.sql 
a;arano
4;newit
[18:05]arano:~$ 

mysql> load data local infile '/home/arano/newit.sql' into table newit fields terminated by ';';  
Query OK, 2 rows affected, 1 warning (0,00 sec)
Records: 2  Deleted: 0  Skipped: 0  Warnings: 1

mysql> select * from newit;
+----+-------+
| id | vname |
+----+-------+
|  0 | arano |
|  1 | hallo |
|  2 | wer   |
|  4 | newit |
+----+-------+
4 rows in set (0,00 sec)

mysql> exit
Bye

mysql> load data infile '/home/arano/newit.sql' into table newit fields terminated by ';';  
> ERROR 1290 (HY000): The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
Also ich bekomme diese Meldung auch und habe die Option auf NULL stehen.
Aber das ist keine Fehlermeldung, das ist eine Sicherheitseinrichtung ! <-- Wichtig, nicht böse face-smile
mysql> select @@global.secure_file_priv;
+---------------------------+
| @@global.secure_file_priv |
+---------------------------+
| NULL                      |
+---------------------------+
1 row in set (0,00 sec)

mysql>

MySQL-Reference
secure_file_priv may be set as follows:
  • If empty, the variable has no effect. This is not a secure setting.
  • If set to the name of a directory, the server limits import and export operations to work only with files in that directory. The directory must exist; the server will not create it.
  • If set to NULL, the server disables import and export operations. This value is permitted as of MySQL 5.7.6.
Also bleibt die Wahl zwischen dem Ändern der Serverkonfiguration oder dem Zeilenweisen Import der Datensätze.


~Arano
em-pie
em-pie 29.01.2018 um 21:39:25 Uhr
Goto Top
Moin,

Kann man nicht dafür sorgen, dass die zu importierende Quelldatei bereits bereinigt ist?

Schlimmstenfalls die ursprungsdatei Zeilenweise auslesen, das erste Feld mit IsDigit/ IsNum (hängt von der verwendeten Scriptsprache ab) das erste Feld prüfen. Wenn IsDigit== true, dann in die neue Importdatei, wenn ==false, dann in eine errordatei.
Dann weisst du auch direkt, welche Daten "strubbelig" sind.

In Summe zwar aufwendiger, aber auch solider.


Gruß
em-pie
newit1
newit1 29.01.2018 um 22:04:02 Uhr
Goto Top
@Arano @em-pie

Danke euch beiden!
Ich denke ich werde dann morgen die Serverkonfiguration ändern.

Finds aber allgemein trotzdem sehr komisch das MySql das durchgehen lässt, wenn ich einen Numerischen Datentyp eingestellt habe....naja
SlainteMhath
SlainteMhath 30.01.2018 um 09:35:31 Uhr
Goto Top
Finds aber allgemein trotzdem sehr komisch das MySql das durchgehen lässt, wenn ich einen Numerischen Datentyp eingestellt habe....naja

Poste doch bitte mal den Output von DESCRIBE <name der import tabelle>

MySQL kann hier nichts "durchgehen lassen", sonst wäre das komplette RDBMS für die Katz...
ukulele-7
ukulele-7 30.01.2018 aktualisiert um 10:17:54 Uhr
Goto Top
MySQL lässt so einiges durchgehen und hat nicht überall den besten Ruf. Du kannst z.B. CHECK Constraints ersellen, sie werden nur nicht beachtet. Du konntest in alten Versionen syntaktisch falsche Selects mit Group By absetzen und es gab keine Fehlermeldung sondern ein (zufälliges) Ergebnis...
newit1
newit1 30.01.2018 um 11:32:06 Uhr
Goto Top