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

Langage SQL Discussion :

probleme cle auto increment


Sujet :

Langage SQL

  1. #1
    Membre à l'essai
    Inscrit en
    Août 2007
    Messages
    30
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 30
    Points : 19
    Points
    19
    Par défaut probleme cle auto increment
    j ai une table (id_cleint,nom_client,prenom_client........) id_client est cle primaire auto increment.
    je veux que lorsque j insere dans la table "insert into client(nom_client,prenom_client,....) values .........) recupérer la valeur du cle primaire de la nouvelle ligne inseree? parcque je dois utiliser cette cle pour un traitement dans une autre table.

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juillet 2007
    Messages : 82
    Points : 92
    Points
    92
    Par défaut
    à priori comme c'est un auto-increment tu n'as qu'a faire un
    select max(id_client) from Client et tu auras la derniere insertion

    tu peux la stocker dans une variable ou pas.

    declare @Max_id int
    set @Max_id=select max(id_client) from Client
    --> ça doit être dur T-SQL ça ...

  3. #3
    Futur Membre du Club
    Inscrit en
    Juin 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Ceci pourra peut-être t'aider :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    $arr = mysql_fetch_array(mysql_query("SHOW TABLE STATUS LIKE 'nom_table'"));
    $next_id = $arr['Auto_increment'];

  4. #4
    Membre chevronné Avatar de philnext
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    1 552
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 1 552
    Points : 1 780
    Points
    1 780
    Par défaut
    Remarque : si tu fais un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     select max(id_client) from Client
    fais le bien dans une transaction avec ta requète d'insertion sinon une requète concurente peux avois inséré un enregistrement entre temps !
    Une solution simple (donc qui évite la transaction) que j'ai adopté est d'insérer un GUID (Google est ton ami si tu ne connais pas) dans chaque enregistrement et de faire le select sur ce GUID pour retrouver ce que je viens d'insérer...

  5. #5
    Membre actif Avatar de AdHoc
    Profil pro
    Inscrit en
    Mai 2003
    Messages
    245
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2003
    Messages : 245
    Points : 239
    Points
    239
    Par défaut
    Bonjour,
    confronter à un problème équivalent, j'avais ajouté 3 champs (poste, utilisateur, date_création) que je passais par variables intermédiaires et que j'utilisais pour le select de récupération de l'ID.
    Pas aussi rigoureux que le GUID, mais très simple à mettre en oeuvre.

Discussions similaires

  1. Probleme d'auto incrementation
    Par kyoshiro94 dans le forum Débuter
    Réponses: 2
    Dernier message: 22/07/2008, 17h27
  2. [ACCES 2007]Cle auto incrementée
    Par mat777 dans le forum Access
    Réponses: 1
    Dernier message: 04/02/2008, 14h26
  3. probleme d'auto increment
    Par Faiche dans le forum Débuter
    Réponses: 18
    Dernier message: 24/07/2007, 17h04
  4. Cle auto incremente mysql
    Par neuneu1 dans le forum SQL Procédural
    Réponses: 6
    Dernier message: 24/04/2007, 16h14
  5. [SQL Server] Cles auto-incrementes
    Par okparanoid dans le forum Bases de données
    Réponses: 3
    Dernier message: 18/11/2006, 23h11

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