I am trying to use proc sql select into to create some macro variables as follows.
%macro sql(var);
proc sql noprint;
select A into: &var. separated by ' ' from in_ds;
quit;
%mend;
%sql(B);
%sql(C);
......
Seems it is not working, tried "&var.", didn't work either. Just wonder how to fix this, thanks.
Unless you use a %GLOBAL statement your macro variables will only be defined within your macro and not available outside of it. Try this:
%macro sql(var);
%global &var.;
proc sql noprint;
select A into: &var. separated by ' ' from in_ds;
quit;
%mend;
%sql(B);
%sql(C);
Unless you use a %GLOBAL statement your macro variables will only be defined within your macro and not available outside of it. Try this:
%macro sql(var);
%global &var.;
proc sql noprint;
select A into: &var. separated by ' ' from in_ds;
quit;
%mend;
%sql(B);
%sql(C);
Good news: We've extended SAS Hackathon registration until Sept. 12, so you still have time to be part of our biggest event yet – our five-year anniversary!
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.