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

SAS Base Discussion :

PROC SQL IN() avec boucle DO()


Sujet :

SAS Base

  1. #1
    Nouveau candidat au Club
    Femme Profil pro
    Statisticienne
    Inscrit en
    Mars 2024
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Statisticienne

    Informations forums :
    Inscription : Mars 2024
    Messages : 1
    Par défaut PROC SQL IN() avec boucle DO()
    Bonjour à tous,

    Je souhaiterais utiliser sur SAS une boucle do avec l'instruction IN() dans une proc sql.

    J'ai crée une liste de macro variables via une invite (&CP1, &CP2, &CP3, ..., &CP31).

    Je souhaiterais écrire le code suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PROC SQL;
    SELECT MaVariable 
    FROM Matable
    WHERE MaVariable IN (&CP1, &CP2, &CP3, ..., &CP31)
    ;
    QUIT;
    Comment y insérer une boucle DO, afin de ne pas écrire 31 fois dans l'instruction IN() s'il vous plaît ?

    Merci par avance pour votre aide !

    Jenifer

  2. #2
    Membre habitué
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2019
    Messages
    14
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2019
    Messages : 14
    Par défaut pas possible
    Bonjour,

    Je pense pas que ce soit possible de faire des loop dans une where clause en sql.

    Deux solution: Soit en sql soit en sas.

    Sql: création d'un table #temporaire, insert des valeur et ensuite: WHERE MaVariable IN (select * from #temp_table)

    SAS: data _null_; cp_all=cp1!!cp2!!cp3 ; call symput('cp_all',cp_all);run;
    et ensuite WHERE MaVariable IN (&cp_all)

Discussions similaires

  1. Réponses: 3
    Dernier message: 17/10/2013, 14h58
  2. [SQL] Proc SQL update avec double lien
    Par GuillaumePr dans le forum SAS Base
    Réponses: 5
    Dernier message: 17/06/2010, 14h33
  3. [SQL] Insert avec boucle
    Par Virgile59 dans le forum Développement
    Réponses: 1
    Dernier message: 05/11/2008, 10h46
  4. Ajouter une colonne avec proc sql
    Par green_fr dans le forum SAS Base
    Réponses: 3
    Dernier message: 08/07/2008, 10h13
  5. [SQL] tri d'un resultat avec boucle for
    Par guillaumeIOB dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 11/09/2007, 14h30

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