在数据处理时,我们往往需要对一个数据集反复读取,例如对照表之类的数据集。一旦数据集尺寸较大时,反复打开和关闭数据集会严重影响程序执行速度,从SAS8.1开始,我们可以使用SASFILE语句将数据集装载到内存,从而减少数据集内存分配和释放的次数,降低I/O处理量,提高SAS程序执行效率。
SASFILE语句的使用非常简单,如下示例:
[code:53ea8]/*创建一个大的数据集*/
data large;
array col(3);
do i=1 to 10000000;
do j=1 to dim(col);
col(j) = ranuni(1);
end;
output;
end;
run;
libname x 'c:\mysaslib';
/*没有使用sasfile语句的情况*//
data x.large;
set large;
run;
/*使用sasfile缓存数据集*/
sasfile large load;
data x.large2;
set large;
run;
proc means data=large;
/*释放缓存数据集*/
sasfile large close;[/code:53ea8]
大家可以通过Log对比两次执行的效率。