楼主: shewenhao
2372 4

[问答] 请教各位高手一个sas sql赋值的问题,谢谢 [推广有奖]

  • 1关注
  • 7粉丝

已卖:1587份资源

讲师

42%

还不是VIP/贵宾

-

威望
0
论坛币
40032 个
通用积分
14.1212
学术水平
4 点
热心指数
6 点
信用等级
3 点
经验
563 点
帖子
235
精华
0
在线时间
617 小时
注册时间
2008-3-7
最后登录
2025-1-16

楼主
shewenhao 发表于 2011-1-8 18:04:56 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
我有data如下

x    y
2   3
3   4
5   1

已经存入了data,先想通过proc sql 取出x的最大值(这个本人会),和y变量的最后一行的值(也就是最后一行的y值: 1)。

我的程序:
proc sql:
         select max(x) as maxX,
         这里该写什么才能让sql去直接读取y列的最后一个observation 1呢?
         from work.data:
quit:


想了半天,网上也search了,高手指点一下,谢啦!!
二维码

扫码加我 拉你入群

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

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

关键词:sql observation proc sql observat Select 请教 高手 SAS sql 赋值

沙发
baoaibaobao 发表于 2011-1-8 19:58:22
  1. data zachary;
  2.         input x y;
  3.         cards;
  4. 2   3
  5. 3   4
  6. 5   1
  7. ;
  8. data zachary;
  9.         set zachary end=last_obs;
  10.         _obs=last_obs;
  11. run;
  12. proc sql;
  13.         create table zachary_1 as
  14.         select max(x) as maxx,
  15.                 (select y from zachary where _obs=1) as lasty  
  16.         from zachary;
  17. quit;
  18.       
复制代码
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
shewenhao + 1 + 1 + 1 He helped me out

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

藤椅
elek.me 发表于 2011-1-10 00:29:52
hi. you can use the MONOTONIC function as follows:
  1. data have;
  2.     input x y;
  3. cards;
  4. 2   3
  5. 3   4
  6. 5   1
  7. ;

  8. proc sql;
  9.         create table want as
  10.         select max(x) as maxX,y from have have having monotonic()=n(x);
  11. quit;
复制代码
已有 1 人评分学术水平 热心指数 收起 理由
Actree + 1 + 1 厉害

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

我的博客: http://elek.me/sas
联系我: http://about.me/elek

板凳
elek.me 发表于 2011-1-10 00:34:45
  1. data have;
  2.     input x y;
  3. cards;
  4. 2   3
  5. 3   4
  6. 5   1
  7. ;

  8. data want(drop=max);
  9.         set have end=eof;
  10.         retain max 0;
  11.         max=max(max,x);
  12.         if eof then do;
  13.                 x=max;
  14.                 output;
  15.         end;
  16. run;
复制代码
不用sql procedure比较简练。
我的博客: http://elek.me/sas
联系我: http://about.me/elek

报纸
Actree 发表于 2011-2-28 08:43:56
明白了,感谢二位高手。原来看似简单的一题还需要动很多脑筋。

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-22 07:40