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

C++Builder Discussion :

MySQL-ODBC - Récupérer l'id après un Insert()


Sujet :

C++Builder

  1. #1
    Membre éclairé
    Inscrit en
    Octobre 2002
    Messages
    343
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 343
    Par défaut MySQL-ODBC - Récupérer l'id après un Insert()
    Bonjour,

    J'utilise un lien ODBC pour accèder à ma bd MySQL. Afin de remplir les champs pour les clés étrangères, je dois récupéré après un insert, la clé primaire INCREMENT AUTO d'une table:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    table->Insert();
    AnsiString asID = table->FieldValues["id"];
    Cette ligne ne marche pas, le champs id est vide. Ce même code devait fonctionner sous ma base Accès.

    Auriez vous une solution ?

    Merci, je bloque depuis 4h dessus!

  2. #2
    Membre confirmé Avatar de marcootz
    Homme Profil pro
    Inscrit en
    Décembre 2006
    Messages
    159
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Décembre 2006
    Messages : 159
    Par défaut
    Salut,

    Comme ca je vous deux possibilités :

    - Si tu utilise une TTable, essaye un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    table->Last();
    table->Open();
    AnsiString asID = tableid->Value; //a condition d'avoir ajouter ton champ en double-cliquant sur la TTable
    Avec ca tu devrais récupérer l'id du dernier enregistrement.


    - Si tu utilise une TQuery, fais une requete "SELECT MAX id FROM table"
    Tu recuperera le plus grand id de la table.

    J'espère t'avoir été utile.
    A+

  3. #3
    Membre Expert
    Avatar de Crayon
    Inscrit en
    Avril 2005
    Messages
    1 811
    Détails du profil
    Informations personnelles :
    Localisation : Autre

    Informations forums :
    Inscription : Avril 2005
    Messages : 1 811
    Par défaut
    Je ne suis pas certain de comment l'utiliser dans ton code (j'utilise l'API MySQL habituellement), mais il existe la commande MySQL:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT LAST_INSERT_ID();
    http://dev.mysql.com/doc/refman/5.1/...last-insert-id

  4. #4
    Membre éclairé
    Inscrit en
    Octobre 2002
    Messages
    343
    Détails du profil
    Informations forums :
    Inscription : Octobre 2002
    Messages : 343
    Par défaut
    Merci beaucoup, ce code fonctionne à merveille.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    table->Last();
    table->Open();
    AnsiString asID = tableid->Value;
    Super

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

Discussions similaires

  1. [PostgreSQL] Récupérer un champ après un INSERT
    Par dgedge03 dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 13/04/2011, 18h26
  2. [MySQL] Récupérer un id aprés un INSERT
    Par Sekigawa dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 06/11/2008, 16h34
  3. Réponses: 5
    Dernier message: 11/01/2007, 15h10
  4. [VB NET]: Récupérer l'ID après une insertion
    Par ADONET dans le forum Windows Forms
    Réponses: 4
    Dernier message: 12/04/2006, 10h26
  5. Réponses: 8
    Dernier message: 25/01/2006, 12h06

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