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

MS SQL Server Discussion :

[SQL Serv. 2K] Récupérer la valeur d'une proc. stock. dans une proc. stock


Sujet :

MS SQL Server

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 11
    Points : 12
    Points
    12
    Par défaut [SQL Serv. 2K] Récupérer la valeur d'une proc. stock. dans une proc. stock
    Bonjour à tous,

    J'ai une procédure stockée de type "SELECT..." qui me renvoit un identifiant. Techniquement, il peut m'en renvoyer autant qu'il en trouve mais dans mon cas, il devrait toujours s'agir d'un seul et unique enregistrement.

    Je souhaite donc appelé cette procédure stockée DEPUIS une autre procédure stockée pour récupérer cet identifiant et l'affecter à une variable local.

    L'idée, en gros, c'est de faire un truc comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    DECLARE @sch_id INT
    SET @sch_id = EXEC ma_procedure_stockee @param1, @param2, @param3
    Ce n'est malheureusement pas possible et je ne vois pas comment procéder...
    Je viens donc chercher conseils et idées

    Merci d'avance,
    Cordialement

    Laurent.

  2. #2
    Membre expérimenté

    Profil pro
    Inscrit en
    Août 2002
    Messages
    1 249
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 1 249
    Points : 1 745
    Points
    1 745
    Par défaut passer par une table temporaire.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations forums :
    Inscription : Mai 2007
    Messages : 356
    Points : 406
    Points
    406
    Par défaut
    Tu as deux choix :


    1/ Renvoyer la valeur de ton identifiant par un RETURN dans première procédure stockée.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    CREATE PROC USP1
    AS
    DECLARE @val INT
    SELECT @val=identifiant FROM ... WHERE ...
    RETURN @val
    GO
     
    CREATE PROC USP2
    AS
    DECLARE @RES INT
    SET @RES= EXEC USP1
    2/Passer par une variable de sortie (ou entrée/sortie)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    CREATE PROC USP1
    @val INT OUTPUT
    AS
    SELECT @val=identifiant FROM ... WHERE ...
    RETURN @val
    GO
     
    CREATE PROC USP2
    AS
    DECLARE @RES INT
    EXEC USP1 @RES OUTPUT
    Maintenant si les retours de ton SELECT sont multiples il faudra utiliser une autre méthode.

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 11
    Points : 12
    Points
    12
    Par défaut
    Ok ça m'a l'air bon. Une p'tite erreur s'est glissé dans le code au niveau de l'appel de la procédure stockée :
    CREATE PROC USP2
    AS
    DECLARE @RES INT
    EXEC @RES = USP1 @params
    Un grand merci !

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 13/11/2009, 17h06
  2. Réponses: 3
    Dernier message: 04/07/2008, 13h00
  3. Réponses: 3
    Dernier message: 07/06/2007, 20h47
  4. Réponses: 1
    Dernier message: 31/07/2006, 14h54
  5. Réponses: 5
    Dernier message: 08/03/2006, 23h20

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