I'm stuck to something about creating tables dynamically by date filter.
I have SAS code for setting date filters before running main codes.
This it the date code;
data _null_;
/*ACTUAL DATES*/
R_act_beg=intnx('month',today(),-12,'beginning');
call symput('R_act_beg',R_act_beg);
R_act_end=intnx('month',today(),-1,'end');
call symput('R_act_end',R_act_end);
name_m=put(month(intnx('month',today(),-1)),z2.);
call symput('name_m',name_m);
name_y_act=put(year(intnx('month',today(),-1)),z4.);
call symput('name_y_act',name_y_act);
nameR_act=name_m||substr(name_y_act,3,4);
call symput('nameR_act',nameR_act);
And this is the one of main codes;
PROC SQL;
CREATE TABLE DATA.PREMIUM&nameR_act AS
SELECT t1.POLICY_NO,
/* SUM_of_PREMIUM */
(SUM(t1.PREMIUM)) FORMAT=22.2 AS SUM_of_PREMIUM
FROM WH.V_PRODUCT t1
WHERE t1.ISSUE_DATE BETWEEN &R_act_beg AND &R_act_end AND t1.PRODUCT_NO IN
(
'421',
'423',
'424',
'425',
'404',
'433',
'430',
'444',
'441',
'443',
'453'
)
GROUP BY t1.POLICY_NO;
QUIT;
So I should run about ten main codes retrospectively for 12 months. Is it possible to create a date code dynamically in order to running main codes for 12 months in one go.