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

Symfony PHP Discussion :

Recuperer lastInsertId apriès insertion [1.x]


Sujet :

Symfony PHP

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 55
    Points : 33
    Points
    33
    Par défaut Recuperer lastInsertId apriès insertion
    Bonjour

    J'ai une question qui me semblait simple...
    Mais j'ai tout essayé sans succès
    Je veut récupérer l'id créer après insertion dans ma base.

    Je crois que j'ai tout essayé :
    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
    ---------------------------------
    protected function processForm(sfWebRequest $request, sfForm $form)
      {
        $form->bind($request->getParameter($form->getName()), $request->getFiles($form->getName()));
        if ($form->isValid())
        {
          $notice = $form->getObject()->isNew() ? 'Inscription crée.' : 'The item was updated successfully.';
     
          try {
            $ newsletterabonnes = $form->save();
            echo  $form->save()->getID() 
            echo '[ ID '. $ newsletterabonnes->getID() .']';
            var_dump(  $ newsletterabonnes->getId()  );
            echo '[ ID '. $ newsletterabonnes->getPrimaryKey().']';
            var_dump(  $ newsletterabonnes->getPrimaryKey()  ); 
    		$id = $this->form->getObject()->id;
            echo '[ ID '. $id .']';
            var_dump(  $id  );
    ---------------------------------
    Une idée ???

    Pi

  2. #2
    Expert éminent
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Points : 8 486
    Points
    8 486
    Par défaut
    L'id est gérée par l'objet du modèle.

    Il n'est disponible dans l'objet qu'après la première sauvegarde.

    Depuis un form.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $this->form->save();
    $id = $this->form->getObject()->getId();
    Code non testé.

    Ceci devrait être bon...
    Si tu donnes un poisson à un homme, il mangera un jour. Si tu lui apprends à pêcher, il mangera toujours (Lao Tseu).

    • Pensez à valoriser les réponses pertinantes, cliquez sur le bouton vert +1 pour indiquer votre accord avec la solution proposée.
    • Pensez à utiliser la balise [code] pour afficher du code, elle est cachée sous le bouton [#] dans l'éditeur.
    • Une discussion est terminée ? Alors le bouton est votre ami !

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 55
    Points : 33
    Points
    33
    Par défaut ca marche
    Je pensais pourtant avoir tout essayé

    Je m'en suis tiré en faisant un select sur ce que je viens d'enregistrer
    mais ç'est vraiment pas optimisé .
    Merci.

  4. #4
    Expert éminent
    Avatar de Michel Rotta
    Homme Profil pro
    DPO
    Inscrit en
    Septembre 2005
    Messages
    4 954
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : DPO
    Secteur : Distribution

    Informations forums :
    Inscription : Septembre 2005
    Messages : 4 954
    Points : 8 486
    Points
    8 486
    Par défaut
    Lors de l'enregistrement de l'objet, doctrine fait déjà cette manipulation et retourne la valeur à l'objet du modèle.

    Regarde les requêtes générées dans le debug.

    As-tu essayés mon code ?

    Attention a ton select es-tu sur d'avoir toujours le bon enregistrement ?
    Si tu donnes un poisson à un homme, il mangera un jour. Si tu lui apprends à pêcher, il mangera toujours (Lao Tseu).

    • Pensez à valoriser les réponses pertinantes, cliquez sur le bouton vert +1 pour indiquer votre accord avec la solution proposée.
    • Pensez à utiliser la balise [code] pour afficher du code, elle est cachée sous le bouton [#] dans l'éditeur.
    • Une discussion est terminée ? Alors le bouton est votre ami !

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    55
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 55
    Points : 33
    Points
    33
    Par défaut ça marche
    Absolument

    ton code marche nickel (Chrome)

    Pi

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

Discussions similaires

  1. recuperer id apres insertion
    Par DaYonyon dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 17/02/2010, 23h16
  2. recuperation données et insertion dans table
    Par amocco dans le forum Débuter
    Réponses: 1
    Dernier message: 25/05/2009, 16h41
  3. [MySQL] recuperer champs et insert en php
    Par samspitz dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 12/02/2009, 16h44
  4. recuperer id d'un insert
    Par peter45781 dans le forum Bases de données
    Réponses: 5
    Dernier message: 24/05/2005, 14h35
  5. Réponses: 16
    Dernier message: 12/04/2005, 14h22

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