楼主: pinggu2688
8376 7

[原创博文] 求助proc sql distinct的问题 [推广有奖]

  • 2关注
  • 0粉丝

博士生

6%

还不是VIP/贵宾

-

威望
0
论坛币
40 个
通用积分
40.2335
学术水平
1 点
热心指数
3 点
信用等级
1 点
经验
3113 点
帖子
166
精华
0
在线时间
103 小时
注册时间
2009-11-12
最后登录
2024-8-28

楼主
pinggu2688 发表于 2011-7-8 05:37:49 |AI写论文
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 ...
关键词:proc sql Distinct Dis Inc IST

本帖被以下文库推荐

沙发
bobguy 发表于 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;

藤椅
soporaeternus 发表于 2011-7-8 08:32:14
原表添加自增ID列
按此列排序
Let them be hard, but never unjust

板凳
pinggu2688 发表于 2011-7-8 09:10:21
能具体些么?谢谢

报纸
honghejing 发表于 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;

地板
honghejing 发表于 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;
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
pinggu2688 + 1 + 1 + 1 观点有启发,有创意

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

7
soporaeternus 发表于 2011-7-8 10:23:40
  1. data a;
  2.         input x;
  3.         datalines;
  4.         1
  5.         2
  6.         1
  7.         3
  8.         2
  9.         4
  10.         5
  11.         5
  12.         1
  13.         2
  14.         ;
  15. run;

  16. data b;
  17.         set a;
  18.         id+1;
  19. run;

  20. proc sql;
  21.         create table c(drop=m) as
  22.         select
  23.                  x
  24.                  ,min(id) as m
  25.         from b
  26.         group by x
  27.         order by
  28.                 m
  29.         ;
  30. quit;
复制代码
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
pinggu2688 + 1 + 1 + 1 我很赞同

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

Let them be hard, but never unjust

8
pinggu2688 发表于 2011-7-12 06:23:04
5# honghejing
如果同样的值连续出现,这个方法是可以实现的,但比如同一个值不是连续出现就不可以了。

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-5 20:14