全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1800 4
2022-06-09
请看附件这段SQL代码? 用在SAS PROC SQL,不支持ROW_NUMBER() OVER PARTITION函数

怎么转为DATA STEP?
附件列表
图片2.png

原图尺寸 22.23 KB

图片2.png

二维码

扫码加我 拉你入群

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

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

全部回复
2022-6-9 14:35:16
这个函数不熟悉,查了一下是分区编号的功能。不知道理解的对不对。
/*row_number() over(partition by sex)*/

proc sort data=sashelp.class;
    by sex;
run;

data test;
    set sashelp.class;
    by sex;
    retain id;
    id+1;
    if first.sex then id=1;
run;

二维码

扫码加我 拉你入群

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

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

2022-6-9 22:31:07
使用SAS下的SQL,仍然有几种可选的做法来生成行号。
1. 连接到Oracle,然后将SQL交给Oracle执行,Oracle的SQL标准不同于SAS的ANSI 1992,row_number()函数受到支持;
2. 使用内置monotonic()函数;
复制代码

3. 使用SAS函数resolve(),并利用SAS逐行处理数据的特点;
复制代码

4. 利用SQL的子查询;
复制代码


应当说明,方法2与3是在读入原数据时生成行号,方法4则是在生成新数据时生成行号,因此结果有所不同。
对方法4略加变化,可以得到符合题意的示例程序:
复制代码
二维码

扫码加我 拉你入群

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

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

2022-6-10 11:25:49
SQL中有PARTITION BY 分组生序号。

你的这几个例子就是重头排序号,没分组吧
二维码

扫码加我 拉你入群

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

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

2022-6-10 16:10:00
jiaqitang11 发表于 2022-6-10 11:25
SQL中有PARTITION BY 分组生序号。

你的这几个例子就是重头排序号,没分组吧
SQL和SAS中的proc sql不可混为一谈。
我的例子中最后一例即分组排序,谈何“没分组吧”?
二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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