SAS中文论坛
标题:
关于程序的效率上的问题
[打印本页]
作者:
shiyiming
时间:
2011-2-24 10:54
标题:
关于程序的效率上的问题
以下是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]
作者:
shiyiming
时间:
2011-2-25 10:35
标题:
Re: 关于程序的效率上的问题
1. where 比 if好,因为where利用了dataset 的数据结构,而且可以用index
2. where的位置越高越好;
这个应该效率最高
data b1;
set a(where=(amt>=2));
run;
作者:
shiyiming
时间:
2011-2-25 12:02
标题:
Re: 关于程序的效率上的问题
这个和把where 写在set 后面应该是一样的把。。。
欢迎光临 SAS中文论坛 (http://mysas.net/forum/)
Powered by Discuz! X3.2