SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 1686|回复: 2
打印 上一主题 下一主题

SASFILE使用方法讲解

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2007-10-12 16:55:37 | 只看该作者

SASFILE使用方法讲解

在数据处理时,我们往往需要对一个数据集反复读取,例如对照表之类的数据集。一旦数据集尺寸较大时,反复打开和关闭数据集会严重影响程序执行速度,从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对比两次执行的效率。

使用SASFILE时需要注意的事项:
1. 确认系统有足够多的内存资源,不要因为SASFILE致使系统资源不足,导致其它作业不能正常完成。
2. SASFILE语句将对数据集进行独占处理,这意味这你不可以覆盖、重命名该文件,也不能重命名变量名或者其长度与类型。
3. 您仍然可以对其数据进行修改和删除
4. 别忘了使用SASFILE CLOSE释放缓存
只有在多次对一个数据集进行处理是才使用
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2007-10-13 21:04:40 | 只看该作者

Re: SASFILE使用方法讲解

呵呵,这个很有用处。。。。。
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2007-10-19 23:30:39 | 只看该作者

Re: SASFILE使用方法讲解

谢谢
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-2-4 10:30 , Processed in 0.067924 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表