SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

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

关于程序的效率上的问题

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2011-2-24 10:54:24 | 只看该作者

关于程序的效率上的问题

以下是4个选择观测的程序,同样的目的。想要知道其原理与效率哪个高。
十分感谢大侠解答;

[code:1o7hp4pd]data a;
     input amt;
     datalines;
1
2
3
;

data b1;
    set  a;
    where amt>=2;
run;

data a;
    modify a;
    if amt <2 then remove;
run;

data b3;
    set a;
    if amt<2 then delete;
run;

proc sql;
     create table b4 as
     delete from a
     where amt<2
;
quit;[/code:1o7hp4pd]
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2011-2-25 10:35:27 | 只看该作者

Re: 关于程序的效率上的问题

1. where 比 if好,因为where利用了dataset 的数据结构,而且可以用index
2. where的位置越高越好;

这个应该效率最高
data b1;
    set  a(where=(amt>=2));
run;
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2011-2-25 12:02:31 | 只看该作者

Re: 关于程序的效率上的问题

这个和把where 写在set 后面应该是一样的把。。。
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-12 18:58 , Processed in 0.072194 second(s), 19 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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