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 :

Assigner une valeur à une variable dans un SELECT ?


Sujet :

MS SQL Server

  1. #1
    Membre du Club
    Profil pro
    Webmaster
    Inscrit en
    Mars 2006
    Messages
    88
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2006
    Messages : 88
    Points : 50
    Points
    50
    Par défaut Assigner une valeur à une variable dans un SELECT ?
    Bonjour à tous,

    J'ai une procédure stockée qui selectionne un jeu de résultat composé d'une seule ligne puis je fais une seconde requete qui à besoin d'une valeur d'une colonne du résultat de la première procédure stockée. Voici comment j'ai procédé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    DECLARE @total int
     
    IF EXISTS(SELECT Column1 FROM LaTable WHERE Column1 = @INPUT_1 AND Column2 = @INPUT_2)
    begin
     
     
    	SELECT TOP(1)
    		Column1,
    		Column2,
    		@total = Column3,
    		Column4,
    		Column5,
    		Column6
    	FROM
    		LaTable
    	WHERE
    		Column1 = @INPUT_1
    		AND Column2 = @INPUT_2;
     
     
    	SELECT * FROM LaTable2 WHERE ColumnA = @total;
     
    end
    J'obtiens l'erreur : A SELECT statement that assigns a value to a variable must not be combined with data-retrieval operations.

    J'ai regardé sur Internet et j'ai vu qu'il fallait assigner chaque colonne à une variable, mais là dans l'exemple, il n'y a que 6 colonnes mais en réalité il y en a une 20ène. Ca fait beaucoup.

    J'attends vos idées car je vois pas de solution là
    Merci d'avance!

  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 restriction.
    tu ne peux pas faire une restriction sur la seule colonne qui t'interesse.

    exemple : select @param = value from table

    tu fais deux requetes :

    la premiere pour affecter ton param

    la seconde pour renvoyer ta ligne...

  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
    Bonjour,

    je pense que dans ton cas il serait plus intéressant de passer par une sous requête. Tes résultats en serait que plus cohérent.
    Bon courage pour la suite.

Discussions similaires

  1. Réponses: 4
    Dernier message: 14/04/2009, 14h12
  2. récupération de la valeur d'une variable dans instruction select
    Par nicole.altuzarra dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 23/01/2009, 12h07
  3. Réponses: 4
    Dernier message: 31/07/2007, 21h52
  4. récupérer une variable dans un select case
    Par rob2-9 dans le forum VB 6 et antérieur
    Réponses: 13
    Dernier message: 23/12/2005, 10h54
  5. Pl/SQL utilisation d'une variable dans un select
    Par larg dans le forum PL/SQL
    Réponses: 17
    Dernier message: 30/11/2004, 17h08

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