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

Macro Discussion :

Liste de valeurs séparées par des , et '


Sujet :

Macro

  1. #1
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    154
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 154
    Points : 61
    Points
    61
    Par défaut Liste de valeurs séparées par des , et '
    Bonjour,

    Je cherche à passer en paramètre une liste de valeurs texte dans un SQL. La liste est créée automatiquement par un SQL et into la variable

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    proc sql ;
    	select 
    		FACTURE_FACIALE_ID into :num_fact separated by ''',''' 
    	from 
    		facture;
    quit ;
    Comme c'est une liste de texte je l'ai encadré de '

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    %let num_fact = %STR(%'&num_fact.%') ;
    Cela doit me donner en théorie 'val1','val2','val3'

    J'ai utilise la variable dans mon proc sql dans une clause where

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    proc sql ;
    	create table detail_user as
    	select 
    		*
    	from 
    		BIM_FULL.V_USE_F_USAGE_VM_M
    	where 
    		1=1
    		and FACTURE_FACIALE_ID in ( &num_fact. )
                   /*and FACTURE_FACIALE_ID in ('50434000','50199758','50612190')*/;
    quit ;
    Et bien ça plante alors que si je met ma liste en dur c'est OK

    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
     
    5539  proc sql ;
    5540      select
    5541          FACTURE_FACIALE_ID into :num_fact separated by ''','''
    5542      from
    5543          facture;
    5544  quit ;
    NOTE: The PROCEDURE SQL printed page 375.
    NOTE: PROCEDURE SQL used (Total process time):
          real time           0.00 seconds
          cpu time            0.00 seconds
     
     
    5545
    5546  %let num_fact = %STR(%'&num_fact.%') ;
    NOTE: Line generated by the macro variable "NUM_FACT".
    5546  50434000','50199758','50612190
                  ---        ---
                  49         49
    NOTE 49-169: The meaning of an identifier after a quoted string may change in a future SAS
                 release.  Inserting white space between a quoted string and the succeeding
                 identifier is recommended.
    5547  %put &num_fact.;
    NOTE: Line generated by the macro variable "NUM_FACT".
    5547   '50434000','50199758','50612190'
                    ---         ---
                    49          49
    '50434000','50199758','50612190'
    NOTE 49-169: The meaning of an identifier after a quoted string may change in a future SAS
                 release.  Inserting white space between a quoted string and the succeeding
                 identifier is recommended.
     
    5548
    5549  proc sql ;
    5550      create table detail_user as
    5551      select
    5552          *
    5553      from
    5554          BIM_FULL.V_USE_F_USAGE_VM_M
    5555      where
    5556          1=1
    5557          and FACTURE_FACIALE_ID in ( &num_fact. );
    NOTE: PROC SQL set option NOEXEC and will continue to check the syntax of statements.
    NOTE: Line generated by the macro variable "NUM_FACT".
    5557   '50434000','50199758','50612190'
                    ---         ---
                    49          49
            -
            22
            -
            76
    NOTE 49-169: The meaning of an identifier after a quoted string may change in a future SAS
                 release.  Inserting white space between a quoted string and the succeeding
                 identifier is recommended.
     
    ERROR 22-322: Syntax error, expecting one of the following: a quoted string, a numeric constant,
                  a datetime constant, a missing value, (, -, SELECT.
     
    ERROR 76-322: Syntax error, statement will be ignored.
     
    5558  quit ;
    NOTE: The SAS System stopped processing this step because of errors.
    NOTE: PROCEDURE SQL used (Total process time):
          real time           0.00 seconds
          cpu time            0.01 seconds
    D'avance merci

  2. #2
    Nouveau membre du Club
    Homme Profil pro
    Dataminer
    Inscrit en
    Septembre 2016
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Dataminer
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2016
    Messages : 29
    Points : 38
    Points
    38
    Par défaut
    Bonjour,

    si tu crées la macro variable complète directement dans la SQL ça ne fonctionne pas ?

    Un code du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    proc sql ;
    	select "'"||FACTURE_FACIALE_ID||"'" into :num_fact separated by "," 
    	from facture;
    quit ;

  3. #3
    Membre du Club
    Inscrit en
    Novembre 2007
    Messages
    154
    Détails du profil
    Informations forums :
    Inscription : Novembre 2007
    Messages : 154
    Points : 61
    Points
    61
    Par défaut
    Je viens de tester ta solution et effectivement ça marche nickel.

    C'est quand même plus simple.


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

Discussions similaires

  1. Réponses: 7
    Dernier message: 27/02/2015, 15h02
  2. récupérer des valeurs séparées par un point virgule
    Par Spaccio dans le forum Requêtes
    Réponses: 9
    Dernier message: 10/04/2009, 11h22
  3. Sélection de données séparées par des lignes et/ou des colonnes vides
    Par Crystalle dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 09/12/2007, 20h02
  4. Champs contenant plusieurs valeurs séparées par ;
    Par sabine34 dans le forum Requêtes
    Réponses: 3
    Dernier message: 11/05/2007, 12h20
  5. Réponses: 3
    Dernier message: 01/10/2005, 21h26

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