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 :

Déplacer une ligne d'une table à l'autre [MySQL]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 64
    Par défaut Déplacer une ligne d'une table à l'autre
    Bonjour!
    Je souhaite, dans le cadre d'un projet, déplacer une ligne d'une table à une autre. Faut il récupérer l'intégralité du champ en php (select * from table1) l executer, le stocker dans uneligne de tableau $data et apres (insert into table2(liste_de_champs) values($data[i]...)

    ou existe t il une méthode plus rapide ?


    Merci d'avance !

    Richard_Rahl

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Ben euh... Vu que ce n'est pas une opération qui est réalisée souvent, je pense que tu vas devoir faire le grand tour, comme tu l'as indiqué...
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 64
    Par défaut
    J'avais oublié de préciser que les structures des tables sont similaires (mêmes champs,mêmes noms...),cela peut-il aider ?

    Merci d'avance!

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    ben, si c'était pas les mêmes structures, tu aurais un gros problème...
    Mais je crains que tu n'es à faire tout le tour... éventuellement avec une boucle tu écrire la requête d'insertion automatiquement.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $req1 = "select * from table1 where [condition]";
    $res1 = mysql_query($req1) or die('erreur sur '.$req1.'<br/>'.mysql_error());
    while ($ligne = mysql_fetch_array($res1))
    {
      $req2 = "insert into table2 values ( '".implode( ' \', \'', $ligne)."' ) ";
      mysql_query($req2) or die('erreur sur '.$req2.'<br/>'.mysql_error());
    }
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre expérimenté Avatar de BlackSmith
    Inscrit en
    Mars 2008
    Messages
    181
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Mars 2008
    Messages : 181
    Par défaut
    Bonjour,


    Essaye de faire comme ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    INSERT INTO ... SELECT ...
    Voici la doc qui va bien : http://dev.mysql.com/doc/refman/5.0/...rt-select.html

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    64
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 64
    Par défaut
    Re !
    En fait dans cette même optique, j'aurais une question: je souhaite récupérer la valeur maximale d'un champ autoincrement d'une bdd ...
    Je pense donc a la requete suivante :
    "SELECT max(id) from table1"

    seulement si la table1 est vide, cela sort 0 alors que l'id stocké en 'cache' vaudra 24, 40 par exemple....
    Cela peut arriver si l'on a déplacé l'intégralité des valeurs de la table dans la nouvelle, celle ci en apparence sera vide mais l'id aura un "compteur" en caché
    Y a t il possibilité de récupérer cette valeur ?
    Merci d avance !

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 09/06/2015, 09h44
  2. Réponses: 2
    Dernier message: 27/02/2015, 10h13
  3. Réponses: 3
    Dernier message: 18/01/2015, 18h30
  4. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  5. déplacer une ligne d'une feuille a une autre
    Par ghosty04 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 15/12/2008, 16h30

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