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 :

SELECT INTO OUTFILE sans ecraser le fichier [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 29
    Par défaut SELECT INTO OUTFILE sans ecraser le fichier
    Bonjour,

    J'ai actuellement un problème, j'essaie d'utiliser la commande
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT * FROM nomtable INTO OUTFILE nomDuFichier
    Sauf que le code suivant fonctionne comme attendu (cad qu'il récupère bien les données dans le fichier indiquer) SAUF QUE le fichier doit forcement ne pas exister.
    Or, je voudrais simplement ajouter des lignes a un fichier texte existant, sans avoir à écraser l'ancien.

    En résumer, je voudrais utiliser cette commande a la manière d'un fwrite, et l’écrire a la fin d'un fichier txt, j'ai déjà fais quelque essais, mais je ne suis arriver a rien.7

    Un peu d'aide serait la bienvenue, merci d'avance.

  2. #2
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 209
    Billets dans le blog
    52
    Par défaut
    Potentiellement tu peux faire cela en deux étapes avec un fichier temporaire.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    file_put_contents('/path_TO_FINAL.txt', file_get_contents('/path_to_TMP.txt'), FILE_APPEND | LOCK_EX);
    Documentation :file_put_contents : Écrit un contenu dans un fichier
    Si le fichier filename n'existe pas, il sera créé. Sinon, le fichier existant sera écrasé, si l'option FILE_APPEND n'est pas définie.
    FILE_APPEND Si le fichier filename existe déjà, cette option permet d'ajouter les données au fichier au lieu de l'écraser.
    file_get_contents : Lit tout un fichier dans une chaîne
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 29
    Par défaut
    Je vais tester ça, merci bien !

  4. #4
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 29
    Par défaut
    Ce que je remarque:
    Le fichier servant de "pont" doit être supprimer après utilisation (sinon l'insertion ne marcheras pas)
    Mais d'après ce que j'ai fais, ça ressemble a ce que j'attends (le données s’écrivent bien sans effacer les autres.

    Nouveau problème de taille, aouter un retour a la ligne

    Voici le code que j'ai fait:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
    		$link = mysqli_connect("localhost","id","mdp","bdd");    		//On effectue la connexion a la BDD: serveur,id,mdp,nom de la bdd
    		if(!$link){
    			die("Erreur de connexion à MySQL");
    		}
    		$pathnew="D:/Uwamp/UwAmp/www/test/ResultImport/path_TO_FINAL.txt";   //Chemin du fichier final
    		$pathtest="D:/Uwamp/UwAmp/www/test/ResultImport/path_to_TMP.txt";      //Chemin du fichier "pont"
    		if(mysqli_query($link,'SELECT * INTO OUTFILE "'.$pathtest.'" FIELDS TERMINATED BY \';\' LINES TERMINATED BY \',\' FROM nomtable')){
    			if(!file_put_contents(''.$pathnew.'', file_get_contents(''.$pathtest.''), FILE_APPEND | LOCK_EX)){
    				echo("Erreur");
    			}
    		}	
    ?>

  5. #5
    Modérateur
    Avatar de grunk
    Homme Profil pro
    Lead dév - Architecte
    Inscrit en
    Août 2003
    Messages
    6 693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Lead dév - Architecte
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 6 693
    Par défaut
    Citation Envoyé par kolodz Voir le message
    Potentiellement tu peux faire cela en deux étapes avec un fichier temporaire.
    A ce moment là autant pas faire un OUTFILE et faire une requête classique qui va écrire dans un fichier via PHP. je dis ca je dis rien

    Pour le saut de ligne un LINES TERMINATED BY '\n' devrait faire le job non ?
    Pry Framework php5 | N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  6. #6
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2017
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2017
    Messages : 29
    Par défaut
    Problème résolu, Voici mon code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    <?php
    		$link = mysqli_connect("localhost","id","mdp","bdd");    		//On effectue la connexion a la BDD: serveur,id,mdp,nom de la bdd
    		if(!$link){
    			die("Erreur de connexion à MySQL");
    		}
    		$pathnew="D:/Uwamp/UwAmp/www/test/ResultImport/path_TO_FINAL.txt";
    		$pathtest="D:/Uwamp/UwAmp/www/test/ResultImport/path_to_TMP.txt";
    		if( file_exists ($pathtest)){    						//Verification de l'existance du fichier
    			unlink($pathtest) ;									//Si il existe, il est supprimer
    		}
    		if(mysqli_query($link,'SELECT * INTO OUTFILE "'.$pathtest.'" FIELDS TERMINATED BY \';\' LINES TERMINATED BY \',\' FROM table')){
    			if(!file_put_contents(''.$pathnew.'', file_get_contents(''.$pathtest.''), FILE_APPEND | LOCK_EX)){
    				echo("Erreur");
    			}
    		}
    //Problématique personelle
    		date_default_timezone_set('Europe/Paris');  
    		$file = fopen("$pathnew", "a");				
    		fwrite($file,date('D,d,M,Y--G\h,i\m,s\s'));	
    		fwrite($file,PHP_EOL);
    		fclose($file);								
    ?>
    PS: J'ai tester le \n dans la commande, mais ca ne marche pas, j'ai donc fait "fwrite($file,PHP_EOL);" et j'obtiens le resultat attendu!
    Merci pour votre aide!

  7. #7
    Modérateur
    Avatar de kolodz
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2008
    Messages
    2 209
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 209
    Billets dans le blog
    52
    Par défaut
    Pense à passer la discussion en résolu.
    Si une réponse vous a été utile pensez à
    Si vous avez eu la réponse à votre question, marquez votre discussion
    Pensez aux FAQs et aux tutoriels et cours.

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

Discussions similaires

  1. Réponses: 5
    Dernier message: 25/05/2016, 15h18
  2. [Sauvegarde] SELECT * INTO OUTFILE ou bien Mysqldump ?
    Par mathieu dans le forum Administration
    Réponses: 17
    Dernier message: 25/04/2013, 16h58
  3. reinstallation sans ecraser le fichier table1.db ?
    Par ouldfella dans le forum Outils
    Réponses: 2
    Dernier message: 27/03/2006, 22h48
  4. Erreur 1045 avec select into outfile
    Par mikaelm dans le forum Administration
    Réponses: 7
    Dernier message: 18/08/2005, 14h45
  5. syntaxe "SELECT * INTO OUTFILE....
    Par mick84m dans le forum Requêtes
    Réponses: 2
    Dernier message: 25/04/2005, 09h53

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