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 :

Mettre à jour une table mysql avec un fichier xml ou csv [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 195
    Points : 77
    Points
    77
    Par défaut Mettre à jour une table mysql avec un fichier xml ou csv
    Bonsoir,
    Je cherche depuis pas mal de temps un moyen de mettre à jour ma table mysql hébergée avec un fichier csv ou xml avec ce protocole:
    1) je télécharge sur le serveur le fichier en question csv ou xml en le choisissant su mon DD local
    2) je mets à jour ma table mysql
    je sais c'est simple mais je n'arrive pas à concrétiser automatiquement.
    Merci.
    Pascal

  2. #2
    Membre expert
    Avatar de ThomasR
    Homme Profil pro
    Directeur technique
    Inscrit en
    Décembre 2007
    Messages
    2 230
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Décembre 2007
    Messages : 2 230
    Points : 3 972
    Points
    3 972
    Par défaut
    Bonsoir,

    As-tu commencé par coder quelque-chose ? Si oui pourrais-tu nous dire ce qui te pose problème exactement.

    Dans le principe il faut simplement que la structure du fichier XML soit basée sur la structure de la base de données.

    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
     
    <?xml version="1.0" encoding="UTF-8"?>
    <database name="Cuisine">
        <table name="Rubriques">
            <row>
                <field name="id"/>
                <field name="nom" value="Patisseries"/>
            </row>
            <row>
                 <field name="id"/>
                 <field name="nom">Plats</field>
            </row>
        </table>
        <table name="Recettes">
            <row>
                 <field name="id"/>
                 <field name="nom">Ghribas à la noix de coco</field>
                 <field name="rubrique_id">patisseries</field> 
            </row>
        </field>
    </database>
    Et tu pourrais traiter ce fichier de la manière suivante :
    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
     
    $document = simple_xml_load_file('databaseupdate.xml');
    foreach($document->database as $database){
        $selected_database = mysql_select_db($database['name']);
        if($selected_database){
            foreach($database->table as $table){
                foreach($table->row as $row){
                    $names = array();
                    $values = array(); 
     
                    foreach($row->field as $field=>$value){
                        $names[] = $field['name'];
                        $values[] = is_int($value) ? $value : '"'.$value.'"';
                    }
     
                    $updt_row_query = 'INSERT INTO `'.$table['name'].'` ('.implode(',', $names).') VALUES('.implode(',', $values).')';
                    mysql_query($udpt_row_query) || die('Erreur mysql pour : '.$updt_row_query);
                }
            }
        }
    }
    En l'occurence le script ne sert qu'à insérer des lignes, mais tu pourrais également en mettre à jour en valorisant la balise field d'attribut id <field name="id">5</field>. Si elle est valorisée, faire un UPDATE SQL.

    J'ai écrit le code vite fait et pas testé mais ca doit être dans ce "délire".

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    195
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 195
    Points : 77
    Points
    77
    Par défaut Je vais essayer
    Merci pour cette piste, je vais essayer de travailler dessus.
    Pascal

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 19/07/2013, 12h24
  2. Réponses: 12
    Dernier message: 14/06/2011, 10h48
  3. Réponses: 4
    Dernier message: 07/08/2008, 15h10
  4. Réponses: 3
    Dernier message: 18/07/2006, 17h37
  5. Prb mettre à jour une table via un fichier excel
    Par antier dans le forum Access
    Réponses: 3
    Dernier message: 02/12/2005, 10h31

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