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
| /* transferer les données de la table traitement_date_2 dans traitement_date , / ! \ attention dans traitement_date_2 les dates sont au format anglais " DDMMMYYY " (exemple 10SEP2014) , dans traitement_date les dates sont aux formats texte pour un traitement de chaine */
PROC SQL ;
CREATE TABLE table traitement_date
(
code_cli char(10),
date_1 char(10),
date_2 char(10),
date_3 char(10)
)
;
run;
proc sql ;
CREATE TABLE traitement_date_2 as
SELECT code, d1 , d2 , d3
FROM client ;
run ;
proc sql ;
/* ici on cherche a transférer le contenu de la table traitement_date_2 dans traitement_date */
INSERT INTO traitement_date (code_cli, date_1 , date_2 , date_3)
VALUES (code, d1 , d2 , d3)
FROM traitement_date_2;
/* ici la fonction ne marche pas ??? */
run;
proc sql;
PROC SQL ;
/* ici on cherche à remplacer le trigramme du mois qui est en lettre et en anglais par le numeros du mois correspondant */
/* ici encore le when n'est pas reconnu pourtant la fonction sql vient d'un site officile SAS avec une proc sql */
UPDATE traitement_date_2
SET 'date_1' = CASE (
WHEN date_1 LIKE '%JAN%' THEN '01'
WHEN date_1 LIKE '%FEB%' THEN '02'
WHEN date_1 LIKE '%MAR%' THEN '03'
WHEN date_1 LIKE '%APR%' THEN '04'
WHEN date_1 LIKE '%MAY%' THEN '05'
WHEN date_1 LIKE '%JUN%' THEN '06'
WHEN date_1 LIKE '%JUL%' THEN '07'
WHEN date_1 LIKE '%AUG%' THEN '08'
WHEN date_1 LIKE '%SEP%' THEN '09'
WHEN date_1 LIKE '%OCT%' THEN '10'
WHEN date_1 LIKE '%NOV%' THEN '11'
WHEN date_1 LIKE '%DEC%' THEN '12'
)
end;
run; |
Partager