IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

Syntaxe requête LOAD DATA INFILE avec php [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 155
    Points : 89
    Points
    89
    Par défaut Syntaxe requête LOAD DATA INFILE avec php
    Bonjour,

    Quand je réalise cette requête directement avec mysql ça fonctionne nickel:
    Code sql : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    LOAD DATA INFILE 'C:/wamp/www/.../test.csv'
    INTO TABLE catalogue_csv
    	FIELDS
    		TERMINATED BY ';'
    		ENCLOSED BY '\"'
    		ESCAPED BY '\\'
    	LINES
    		STARTING BY ''
    		TERMINATED BY '\n'
    		(ArtNumber, Title, ..., Color)

    Par contre si je la fait avec php:
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $sql = "LOAD DATA INFILE 'C:/wamp/www/.../test.csv'
              INTO TABLE catalogue_csv
    		FIELDS
    			TERMINATED BY ';'
    			ENCLOSED BY '\"'
    			ESCAPED BY '\\'
    		LINES
    			STARTING BY ''
    			TERMINATED BY '\n'
    			(ArtNumber, Title, ..., Color)";
     
    $requete_sql = mysql_query($sql) or die(mysql_error());

    J'ai le message suivant:

    You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '' (ArtNumber, Title, Description_Short, DisplayPrice, Img_url, Deeplink1, P' at line 7
    Voyez-vous ou est le problème ?
    Je pense que cela viens des différents / et " dans la requête mais je n'arrive pas à trouver de solution.

    Merci d'avance.

  2. #2
    Membre actif
    Inscrit en
    Mai 2010
    Messages
    177
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 177
    Points : 210
    Points
    210
    Par défaut
    Sans être 100% certain, je crois que le problème vient des clauses "enclosed by", "escaped by" et "Terminated by". La raison pour cela vient du fait que le PHP va 'échapper' les caractères spéciaux dans ta chaîne de caractère résultant ultimement au résultat suivant étant passé à MySQL:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    LOAD DATA INFILE 'C:/wamp/www/.../test.csv'
    INTO TABLE catalogue_csv
    	FIELDS
    		TERMINATED BY ';'
    		ENCLOSED BY '"'
    		ESCAPED BY '\'
    	LINES
    		STARTING BY ''
    		TERMINATED BY '
    '
    		(ArtNumber, Title, ..., Color)
    Évidemment, MySql ne comprendra pas cette commande qui est un peu bizarre pour lui. Si tu veux rigoureusement garder la même syntaxe (conserver \", \\ et \n), tu dois prévoir le tout en conséquence de la façon suivante:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    LOAD DATA INFILE 'C:/wamp/www/.../test.csv'
    INTO TABLE catalogue_csv
    	FIELDS
    		TERMINATED BY ';'
    		ENCLOSED BY '\\\"'
    		ESCAPED BY '\\\\'
    	LINES
    		STARTING BY ''
    		TERMINATED BY '\\n'
    		(ArtNumber, Title, ..., Color)
    Je ne sais pas si cela va résoudre ton problème, mais ça ne coûte pas grand chose d'essayer . La meilleure façon de savoir si ta chaîne est correcte est encore de faire un echo du contenu de $sql, cela devrait te donner un indice plus précis de où se trouve l'erreur

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Février 2008
    Messages
    155
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 155
    Points : 89
    Points
    89
    Par défaut
    Merci, je m'en suis sortie en faisant echo $sql, il manquait quelques \

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    $sql = "LOAD DATA INFILE 'C:/wamp/www/.../test.csv'
              INTO TABLE catalogue_csv
    		FIELDS
    			TERMINATED BY ';'
    			ENCLOSED BY '\\\"'
    			ESCAPED BY '\\\\'
    		LINES
    			STARTING BY ''
    			TERMINATED BY '\\n'
    			(ArtNumber, Title, ..., Color)";
     
    $requete_sql = mysql_query($sql) or die(mysql_error());

    osuwariboy: Ta solution était bonne.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Load Data Infile avec Wamp
    Par Eleanor dans le forum Requêtes
    Réponses: 177
    Dernier message: 11/07/2012, 13h03
  2. load data infil avec valeur passée avec $1
    Par ldiaz dans le forum Requêtes
    Réponses: 0
    Dernier message: 13/05/2012, 16h34
  3. Vitesse de LOAD DATA INFILE avec un gros fichier
    Par Nasky dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/05/2012, 19h18
  4. Syntax error LOAD DATA INFILE
    Par dnode57 dans le forum Requêtes
    Réponses: 1
    Dernier message: 30/07/2008, 12h15
  5. Fonction LOAD DATA INFILE avec un fichier source csv
    Par mabret dans le forum SQL Procédural
    Réponses: 5
    Dernier message: 25/03/2008, 14h06

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo