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 :

Insérer la date du dernier trimestre dans une table avec INSERT INTO et VALUE [SQL]


Sujet :

SAS Base

  1. #1
    Membre actif
    Femme Profil pro
    Analyste en Intelligence d'Affaires (BI)
    Inscrit en
    Avril 2008
    Messages
    245
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Canada

    Informations professionnelles :
    Activité : Analyste en Intelligence d'Affaires (BI)
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 245
    Points : 290
    Points
    290
    Par défaut Insérer la date du dernier trimestre dans une table avec INSERT INTO et VALUE
    Bonjour,
    J'aimerai insérer la date du dernier trimestre (en la calculant) dans une table existante à laquelle je me connecte.
    J'ai essayé plusieurs solutions non fructueuses pour le moment...calculé le trimestre en soi j'ai réussi maintenant mon problème est celui d'insérer la valeur du résultat ou l'expression de calcul dans la clause VALUE
    Voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    proc sql;
        connect to netezza (DATABASE=&netezzaDB server=&netezzaServer USER=&netezzaUser password=&netezzaPwd connection=SHARED);
    	select	*
    	from connection to netezza
    	(
    		INSERT INTO NDWXXP10..PROCEDURETRACKER_HIST (DATA_SOURCE
                , LOADENDDATE
                , DATA_ASOF
                , SOURCE_SYSTEM
            ) VALUES ('NOMDELAPROC', now(), dernier trimestre ici en date auj 2018-06-30 00:00:00, 'SAS');
    	);
    	disconnect from netezza;
    quit;
    Pour calculer le trimestre j'utilise
    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
     
    DATA _null_;
    length lastqtr $6.;
    XDATE1 = PUT(INTNX('quarter',today(),-1,'E'),yymmddn.); 
    lastqtr=trim(substr(XDATE1,1,6));
    CALL SYMPUT('lastqtr',lastqtr);
     
    XDATE2 = PUT(INTNX('quarter',today(),-1,'B'),yymmdd10.); 
    qtrstart=trim(translate(XDATE2, '/', '-'));
    CALL SYMPUT('qtrstart',qtrstart);
     
    XDATE3 = PUT(INTNX('quarter',today(),-1,'E'),yymmdd10.); 
    qtrend=trim(translate(XDATE3,'/', '-'));
    CALL SYMPUT('qtrend',qtrend);
    RUN;
    ou

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    data test;
       format end_last_q date9.;
       end_last_q = intnx('qtr', today(), -1, 'end');
       put end_last_q;
     
    run;
    L'utilisation de la macro &qtrend a quasi marché mais là j'ai un problème de format car DATE_ASOF est un TIMESTAMP.
    Un sous select avec la variable end_last_q n'a pas marché
    Insertion directe de l'expression de calcul non plus.

    Merci.

  2. #2
    Membre actif
    Femme Profil pro
    Analyste en Intelligence d'Affaires (BI)
    Inscrit en
    Avril 2008
    Messages
    245
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Canada

    Informations professionnelles :
    Activité : Analyste en Intelligence d'Affaires (BI)
    Secteur : Conseil

    Informations forums :
    Inscription : Avril 2008
    Messages : 245
    Points : 290
    Points
    290
    Par défaut solution
    Bonjour,

    J'ai finalement trouvé une solution que voici :
    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
     
    DATA _null_;
    length lastqtr $6.;
    XDATE1 = PUT(INTNX('quarter',today(),-1,'E'),yymmddn.); 
    lastqtr=trim(substr(XDATE1,1,6));
    CALL SYMPUT('lastqtr',lastqtr);
     
    XDATE2 = PUT(INTNX('quarter',today(),-1,'B'),yymmdd10.); 
    qtrstart=trim(translate(XDATE2, '/', '-'));
    CALL SYMPUT('qtrstart',qtrstart);
     
    XDATE3 = PUT(INTNX('quarter',today(),-1,'E'),yymmdd10.); 
    qtrend=trim(translate(XDATE3,'-', '/'));
    CALL SYMPUT('qtrend', XDATE3);
     
    %put &qtrstart &lastqtr &qtrend;
    run;
     
    %let datequarter = %str(%'&qtrend.%');
    %put &datequarter.;
     
    proc sql;
        connect to netezza (DATABASE=NDWXXP10 &nzpassprod);
     
          execute
          (
                INSERT INTO NDWXXP10..PROCEDURETRACKER_HIST (DATA_SOURCE
                , LOADENDDATE
                , DATA_ASOF
                , SOURCE_SYSTEM
            ) VALUES ('ADP023_KANETIX_QTR', now(), &datequarter::TIMESTAMP, 'SAS');
          ) by netezza;
          disconnect from netezza;
    quit;
    L'idée principale est de transformer la date et d'appliquer un format TIMESTAMP.


    Merci

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 31/08/2016, 13h03
  2. Réponses: 6
    Dernier message: 23/03/2015, 15h43
  3. Réponses: 1
    Dernier message: 27/03/2011, 19h50
  4. Insertion d'une date dans une table avec vba
    Par skeut dans le forum Access
    Réponses: 2
    Dernier message: 21/02/2006, 08h54
  5. Insérer le contenue d'un memo dans une table mysql
    Par kijudr dans le forum Bases de données
    Réponses: 1
    Dernier message: 05/12/2005, 08h39

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