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# Discussion :

récupérer la clé générée en c#


Sujet :

C#

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 247
    Points : 78
    Points
    78
    Par défaut récupérer la clé générée en c#
    Bonjour,
    suite à l'insertion dans une base j'aimerais récupérer la clé (auto-incrémentée) qui a été générée. Je développe en c# et j'utilise un connecteur .net fourni par mysql.

    Je ne trouve pas de documentation à ce sujet.

    Merci pour votre aide.

  2. #2
    Membre confirmé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2009
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Février 2009
    Messages : 317
    Points : 560
    Points
    560
    Par défaut
    Bonjour,
    Pourquoi ne pas simplement faire une requête Max des valeurs de ta colonne ?

  3. #3
    Membre éclairé Avatar de ppphil
    Profil pro
    Inscrit en
    Juin 2007
    Messages
    612
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2007
    Messages : 612
    Points : 685
    Points
    685
    Par défaut
    Recherche un peu "last_insert_id()".....

  4. #4
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 749
    Points
    39 749
    Par défaut
    Citation Envoyé par Aeronia Voir le message
    Bonjour,
    Pourquoi ne pas simplement faire une requête Max des valeurs de ta colonne ?
    D'abord parce que c'est pas forcément le max, ça dépend de l'algorithme utilisé pour générer la valeur
    Ensuite parce que si d'autres processes travaillent sur la même base, il peut très bien y en avoir un qui insère autre chose entre le moment où tu insères et celui où tu récupères la valeur

    Il faut utiliser la fonction LAST_INSERT_ID, comme expliqué ici :
    http://stackoverflow.com/questions/4.../405922#405922

    en gros tu rajoutes l'appel à LAST_INSERT_ID à la fin de ta requête :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO ... VALUES... ; SELECT LAST_INSERT_ID();

    Et tu exécutes ça avec ExecuteScalar pour récupérer la valeur renvoyée

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 247
    Points : 78
    Points
    78
    Par défaut
    Merci pour vos réponses.
    Je connaissais last_insert_id, mais je suis plus spécialiste de JDBC qui propose des requêtes préparées qui disposent de méthodes fournissant la clé générée.
    Je pensais qu'il en était de même en .net.

    Mer'ci encore à tous

  6. #6
    Membre confirmé
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2009
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Finance

    Informations forums :
    Inscription : Février 2009
    Messages : 317
    Points : 560
    Points
    560
    Par défaut
    Citation Envoyé par tomlev Voir le message
    D'abord parce que c'est pas forcément le max, ça dépend de l'algorithme utilisé pour générer la valeur
    Ensuite parce que si d'autres processes travaillent sur la même base, il peut très bien y en avoir un qui insère autre chose entre le moment où tu insères et celui où tu récupères la valeur

    Il faut utiliser la fonction LAST_INSERT_ID, comme expliqué ici :
    http://stackoverflow.com/questions/4.../405922#405922

    en gros tu rajoutes l'appel à LAST_INSERT_ID à la fin de ta requête :
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    INSERT INTO ... VALUES... ; SELECT LAST_INSERT_ID();

    Et tu exécutes ça avec ExecuteScalar pour récupérer la valeur renvoyée
    Ah oui en effet j'avais pas pensé à ce détail important x)

Discussions similaires

  1. [GD] Récupérer l'image générée par un script PHP
    Par Rafsky dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 22/08/2008, 11h53
  2. [MySQL] Récupérer les informations générées dynamiquement
    Par Senji dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 06/08/2008, 16h19
  3. Récupérer une variable générée avec php
    Par nikitou dans le forum Flash
    Réponses: 2
    Dernier message: 30/07/2007, 15h41
  4. Récupérer une image générée par un lien
    Par furtif1 dans le forum Langage
    Réponses: 1
    Dernier message: 03/05/2007, 11h11
  5. Réponses: 8
    Dernier message: 20/02/2007, 15h16

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