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

ASP.NET Discussion :

Insertion dans base SQL et recuperation du dernier enregistrement


Sujet :

ASP.NET

  1. #1
    Membre habitué Avatar de jubourbon
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 540
    Points : 189
    Points
    189
    Par défaut Insertion dans base SQL et recuperation du dernier enregistrement
    Bonjour,

    Je souhaites enregistrer des informations dans un base sql depuis un formulaire sur une page ASP.Net
    J'utilise pour ca ADO.Net.
    J'insère dans une table Personne un nom et un prénom. Chaque enregistrement de cette table possède un id qui s'autoincremente.
    J'aurais besoin une fois enregistrer de récupérer cet ID du cet élément que je viens d'insérer.

    Je prévois de faire une requête qui me renvoi le dernier élément enregistré,mais c'est pas très sur en cas d'enregistrement simultané et c'est pas top.

    Pourriez vous me conseiller une autre méthode?
    Les meilleures sauces de salade sont sur www.sauce-salade.com
    SpBreak la pause SharePoint: SP Break

  2. #2
    Membre confirmé Avatar de Redouane
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    435
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2003
    Messages : 435
    Points : 569
    Points
    569
    Par défaut
    Bnj,

    J'espère que ça va t'aider :

    http://msdn.microsoft.com/en-us/libr...(v=vs.80).aspx

    Bonne courage.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Redouane me = new Redouane();
    if (me.Connect())
        me.ShareInformations();

  3. #3
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Citation Envoyé par jubourbon Voir le message
    Pourriez vous me conseiller une autre méthode?
    - Faire une proc stoc réalisant l'insertion et retournant l'id recupéré avec la fonction @@identity, qui sera retourné dans un paramètre OUTPUT de la proc stoc (le code de retour devant plutôt être réservé à une information de type ok/ko , même si techniquement rien n'empêche de l'utiliser pour cet usage).

    - Questionner le fait d'avoir besoin de champs incrémentaux : si c'est un élement d'identication "métier" (numéro de client par exemple) ça se justifie, si c'est un élément d'unicité technique uniquement, un uniqueidentifier me semble bien plus adapté et peut être généré par le code client.

    Je ne réponds pas aux questions techniques par MP ! Le forum est là pour ça...


    Une réponse vous a aidé ? utiliser le bouton

    "L’ennui dans ce monde, c’est que les idiots sont sûrs d’eux et les gens sensés pleins de doutes". B. Russel

  4. #4
    Membre habitué Avatar de jubourbon
    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    540
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Octobre 2008
    Messages : 540
    Points : 189
    Points
    189
    Par défaut
    Merci pour ton aide, cette page est bien complète et je ne l'avais pas rencontrée avant.
    Les meilleures sauces de salade sont sur www.sauce-salade.com
    SpBreak la pause SharePoint: SP Break

  5. #5
    Membre éprouvé
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Juillet 2007
    Messages
    693
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Juillet 2007
    Messages : 693
    Points : 1 187
    Points
    1 187
    Par défaut
    Citation Envoyé par Bluedeep Voir le message
    - Faire une proc stoc réalisant l'insertion et retournant l'id recupéré avec la fonction @@identity, qui sera retourné dans un paramètre OUTPUT de la proc stoc (le code de retour devant plutôt être réservé à une information de type ok/ko , même si techniquement rien n'empêche de l'utiliser pour cet usage).

    - Questionner le fait d'avoir besoin de champs incrémentaux : si c'est un élement d'identication "métier" (numéro de client par exemple) ça se justifie, si c'est un élément d'unicité technique uniquement, un uniqueidentifier me semble bien plus adapté et peut être généré par le code client.
    Euh, il faut tout de même faire attention avec @@identity, selon moi, il convient mieux d'utiliser scope_identity (cf l'extrait de MSDN à ce sujet)
    SCOPE_IDENTITY
    Returns the last identity value within the current execution scope. SCOPE_IDENTITY is recommended for most scenarios.

    @@IDENTITY
    Contains the last identity value generated in any table in the current session. @@IDENTITY can be affected by triggers and may not return the identity value that you expect.

    IDENT_CURRENT
    Returns the last identity value generated for a specific table in any session and any scope.

  6. #6
    Inactif  
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Janvier 2007
    Messages
    6 604
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC

    Informations forums :
    Inscription : Janvier 2007
    Messages : 6 604
    Points : 13 314
    Points
    13 314
    Par défaut
    Citation Envoyé par ostenhard Voir le message
    Euh, il faut tout de même faire attention avec @@identity, selon moi, il convient mieux d'utiliser scope_identity (cf l'extrait de MSDN à ce sujet)
    Dans l'absolu tu as tout à fait raison, mais cela n'a de réalité concréte que dans une architecture avec un environnement de réplication (dans la mesure où tu utilise la fonction dans l'instruction suivant l'insertion), or je ne pense pas que cela soit le cas ici.

    Mais tu as parfaitement raison de souligner la nuance.

    Microsoft dit :

    @@IDENTITY is not a reliable indicator of the most recent user-created identity if the column is part of a replication article.

    Je ne réponds pas aux questions techniques par MP ! Le forum est là pour ça...


    Une réponse vous a aidé ? utiliser le bouton

    "L’ennui dans ce monde, c’est que les idiots sont sûrs d’eux et les gens sensés pleins de doutes". B. Russel

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

Discussions similaires

  1. Réponses: 13
    Dernier message: 10/02/2015, 09h01
  2. Insert dans base sql erroné
    Par krapoulos dans le forum Langage
    Réponses: 1
    Dernier message: 18/10/2010, 06h14
  3. recuperer le dernier enregistrement dans un table sql
    Par moukit233 dans le forum Windows Forms
    Réponses: 1
    Dernier message: 23/07/2009, 12h16
  4. [SQL] Problème insertion dans Base SQL après saisie d'un formulaire
    Par Yagami_Raito dans le forum PHP & Base de données
    Réponses: 16
    Dernier message: 15/05/2007, 13h44
  5. Réponses: 2
    Dernier message: 23/11/2006, 10h37

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