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 :

récupérer un enregistrement avec lastinsertid [PDO]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut récupérer un enregistrement avec lastinsertid
    Bonjour,

    j'effectue la copie d'une ligne de la sorte :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    // copy in `machines` table : all keys except name because unique key and so update request
    	$sql='INSERT INTO `machines` (localization,pays,entite,perimetre,type,comment,contact_name,ip,contact_phone)
    	SELECT localization,pays,entite,perimetre,type,comment,contact_name,ip,contact_phone
    	FROM `machines` where name="'.$machselcopy.'"';
     
    	$bdd->query($sql);
     
    	$id_copy=$bdd->lastinsertid();
     
    	$sql='update `machines` SET name="'.$name_copy.'" where id="'.$id_copy.'"';
    	$bdd->query($sql);
    ce code fonctionnait bien en local (Wampserver), mais mis en ligne, where id="'.$id_copy.'"' n'existe pas. Donc comment récupérer la ligne que je viens de créer avec l'insert de la ligne 2 ?

    structure de la table machines :
    Code sql : 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
    CREATE TABLE `machines` (
      `name` varchar(20) COLLATE latin1_bin DEFAULT NULL,
      `localization` varchar(30) COLLATE latin1_bin DEFAULT NULL,
      `pays` varchar(30) COLLATE latin1_bin NOT NULL DEFAULT '',
      `entite` varchar(20) COLLATE latin1_bin DEFAULT NULL,
      `perimetre` set('Oui','Non') COLLATE latin1_bin DEFAULT NULL,
      `type` varchar(20) COLLATE latin1_bin DEFAULT NULL,
      `id` smallint(6) NOT NULL,
      `comment` varchar(100) COLLATE latin1_bin DEFAULT NULL,
      `ip` varchar(15) COLLATE latin1_bin DEFAULT NULL,
      `contact_name` varchar(50) COLLATE latin1_bin DEFAULT NULL,
      `contact_phone` varchar(50) COLLATE latin1_bin DEFAULT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=latin1 COLLATE=latin1_bin;
     
    ALTER TABLE `machines`
      ADD PRIMARY KEY (`id`),
      ADD UNIQUE KEY `name` (`name`);

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour Laurent,

    1/ quand une fonction s'écrit avec des majuscules/minuscules, il faut les RESPECTER !



    2/ AUCUNE requête préparée dans ton code..... ... ni vérification des données transmises ou reçues...

  3. #3
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 493
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 493
    Billets dans le blog
    1
    Par défaut
    Bonsoir Jérôme,

    quand j'ai repensé à ta remarque sans avoir le code sous les yeux, j'ai pensé à un autre et me suis dit que ta boule de cristal était réparée pour le point 2 mais maintenant que je revois le code, je comprend mieux ! OK, par contre la requête avec l'insert et un select pour déterminer les valeurs, je vois comment faire une requête préparée...
    Mais le principal, c'est de faire marcher ce code, donc le point 1...sauf que je suis retombé sur le problème évoqué dans https://www.developpez.net/forums/d1...ariable-_post/ : ça recommence...T'aurais pas une idée pour ça ?

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

Discussions similaires

  1. [PHP 5.3] Récupérer un Array avec étiquette enregistré dans un fichier .txt
    Par Myst3ryssss dans le forum Langage
    Réponses: 6
    Dernier message: 08/03/2012, 10h17
  2. Récupérer tous les enregistrements avec SQLite
    Par 304bl dans le forum Android
    Réponses: 4
    Dernier message: 04/02/2012, 12h52
  3. [AC-2000] Récupérer un enregistrement avec champ vide
    Par Remus91 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 29/07/2009, 15h20
  4. Comment récupérer le dernier enregistrement avec MYSQLI ?
    Par Alexandrebox dans le forum Requêtes
    Réponses: 1
    Dernier message: 10/04/2009, 18h29
  5. Comment récupérer des données enregistrées avec Rapid File ?
    Par didmarj2a dans le forum Bases de données
    Réponses: 2
    Dernier message: 21/03/2008, 09h49

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