全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
8346 7
2011-07-08
悬赏 30 个论坛币 已解决
如果用proc sql;
create table dataset2  as
select distinct a as b
from dataset1;
quit;
这样的变量b是按照b的大小顺序排列的,而不是按照原来a的顺序排列的,请问如何可以使b的排列顺序不变?

谢谢

最佳答案

bobguy 查看完整内容

I believe you cannot do it with distinct, but you may bypass it as in the example below, data t1; do i=1 to 20; a=ceil(ranuni(127)*5); output; end; keep a; run; proc print;run; proc sql; create table t2 as select a as b, min(N) as ord from ( select a , monotonic() as N from t1 ) group by 1 order by 2 ; quit; proc ...
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2011-7-8 05:37:50
pinggu2688 发表于 2011-7-8 05:37
如果用proc sql;
create table dataset2  as
select distinct a as b
from dataset1;
quit;
这样的变量b是按照b的大小顺序排列的,而不是按照原来a的顺序排列的,请问如何可以使b的排列顺序不变?

谢谢
I believe you cannot do it with distinct, but you may bypass it as in the example below,

data t1;
   do i=1 to 20;
      a=ceil(ranuni(127)*5);
   output;
   end;
   keep a;
run;
proc print;run;
proc sql;
create table t2 as
  select a as b, min(N) as ord
  from (
         select a , monotonic() as N
         from t1
        )
  group by 1
  order by 2
  ;
  quit;
  proc print;run;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2011-7-8 08:32:14
原表添加自增ID列
按此列排序
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2011-7-8 09:10:21
能具体些么?谢谢
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2011-7-8 09:51:58
他的意思是
data dataset1;
set dataset1;
id=_n_;
run;

proc sql;
create table dataset2  as
select distinct a as b
from dataset1
order by id;
quit;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2011-7-8 09:54:30
我试了一下,不行的,你没必要按照a的原来顺序排列,因为a里面有些重复出现的不一定以次出现。一般用sql distinct的话,系统会自动排序,如果是以次出现的话可以用下面的程序去做:
data a;
input a;
cards;
3
3
1
1
2
;
run;
data b;
set a;
d=lag(a);
retain n 1;
if _n_=1 then n=1;
else do;
if a^=d then n+1;
end;
run;
proc sql;
create table c  as
select distinct n,a as b
from b
order by n;
quit;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群