楼主: shenliang_111
7473 3

[问答] PROC SQL如何实现分组排序 [推广有奖]

  • 3关注
  • 12粉丝

教授

15%

还不是VIP/贵宾

-

威望
0
论坛币
14 个
通用积分
0.4174
学术水平
20 点
热心指数
26 点
信用等级
12 点
经验
17989 点
帖子
478
精华
0
在线时间
1627 小时
注册时间
2011-2-24
最后登录
2025-8-3

楼主
shenliang_111 发表于 2013-12-6 13:44:28 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
一个讨论:

分组排序功能在数据分析中非常常见,在常见数据库中(例如oracle、Postgresql)中均可采用row_number() over(partition by ...)语句
,不知道在PROC SQL中有没有对应实现的方法!



谢谢大家了!


二维码

扫码加我 拉你入群

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

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

关键词:proc sql 如何实现 ROC sql PostgreSQL 如何

沙发
soporaeternus 发表于 2013-12-6 14:15:11
干儿子还是不行的,还是要靠亲儿子啊
个人感觉是data step里稍微方便点
Let them be hard, but never unjust

藤椅
shenliang_111 发表于 2013-12-6 15:12:10
soporaeternus 发表于 2013-12-6 14:15
干儿子还是不行的,还是要靠亲儿子啊
个人感觉是data step里稍微方便点
嗯..目前只想到用first.分组变量来搞了...

板凳
bobguy 发表于 2013-12-8 06:58:14
Here are several ways to group your data.

data t1;
   call streaminit(123);
   do i=1 to 100;
      x=rand('chisquare',2);
          output;
        end;
run;


proc sql;
  select x, int((i-1)/10) as group
  from t1
  order by 2
  ;
quit;

proc sql;
  select x, int((monotonic()-1)/10)  as group
  from t1
  order by 2
  ;
quit;

proc sql;
  select x, ceil(10*ranuni(123)) as group
  from t1
  order by 2
  ;
quit;

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

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