楼主: susanzhu
3402 8

[问答] proc sql合并数据集出错 [推广有奖]

  • 0关注
  • 0粉丝

硕士生

37%

还不是VIP/贵宾

-

威望
0
论坛币
1347 个
通用积分
0.3604
学术水平
2 点
热心指数
3 点
信用等级
2 点
经验
1967 点
帖子
89
精华
0
在线时间
140 小时
注册时间
2007-11-6
最后登录
2024-4-22

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
我的程序如下:
proc sql;
   create table ac as
   select a2.*,bt2.*
   from a2 a, bt2 b
   where a.permno=b.permno and a.analyst=b.analyst and a.forecastdate=b.forecastdate;
quit;
本意是有a2(有permno analyst forecastdate recommendation几个变量)和bt2(有permno analyst forecastdate ANALYS value actual几个变量),目的是合并a2和bt2两个数据库,需要满足permno analyst forecastdate都匹配。
提交上述语句后sas日志出现如下文字:
WARNING: 变量 forecastdate 已经存在于文件“WORK.AC”中。
WARNING: 变量 analyst 已经存在于文件“WORK.AC”中。
WARNING: 变量 PERMNO 已经存在于文件“WORK.AC”中。
NOTE: 表 WORK.AC 创建完成,有 0 行,7 列。

不知道问题出在哪里,请各位大牛指教,多谢了。
二维码

扫码加我 拉你入群

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

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

关键词:proc sql 合并数据 sql ROC 数据集

沙发
susanzhu 发表于 2017-8-6 23:24:18 |只看作者 |坛友微信交流群
之前试图通过merge合并,但是merge命令中by后面加了permno analyst forecastdate,得到的结果完全是将两个数据集set到一起一样,by命令后不能超过两个变量吗?

使用道具

藤椅
67890 发表于 2017-8-6 23:37:49 |只看作者 |坛友微信交流群
你引入这3个变量2次。重名了。可以忽略这些警告。


WARNING: 变量 forecastdate 已经存在于文件“WORK.AC”中。
WARNING: 变量 analyst 已经存在于文件“WORK.AC”中。
WARNING: 变量 PERMNO 已经存在于文件“WORK.AC”中。
已有 1 人评分经验 学术水平 热心指数 信用等级 收起 理由
阿扁V5 + 20 + 2 + 2 + 2 热心帮助其他会员

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

使用道具

板凳
susanzhu 发表于 2017-8-6 23:43:57 |只看作者 |坛友微信交流群
67890 发表于 2017-8-6 23:37
你引入这3个变量2次。重名了。可以忽略这些警告。
我是根据下面这个程序写的
proc sql;
    create table innerjoins as
    select a.*,b.*
    from March a,Delay b
    where a.flight=b.flight and a.date=b.date;
quit;
http://blog.sina.com.cn/s/blog_5d3b177c0100cm1t.html
现在还有一个主要问题是做出来合并数据集没有观测,根据我对数据的比照不能一个观测都没有的。

使用道具

报纸
susanzhu 发表于 2017-8-6 23:45:44 |只看作者 |坛友微信交流群
67890 发表于 2017-8-6 23:37
你引入这3个变量2次。重名了。可以忽略这些警告。
我是根据这个网页上推荐的程序写的:
http://blog.sina.com.cn/s/blog_5d3b177c0100cm1t.html
具体程序是
proc sql;
    create table innerjoins as
    select a.*,b.*
    from March a,Delay b
    where a.flight=b.flight and a.date=b.date;
quit;
我的问题还有合并完了新的数据集一个data也没有,这样不对。

使用道具

地板
susanzhu 发表于 2017-8-6 23:58:34 |只看作者 |坛友微信交流群
为什么回复还要审核呢?
我是根据这个网页上推荐的程序写的:
http://blog.sina.com.cn/s/blog_5d3b177c0100cm1t.html
具体程序是
proc sql;
    create table innerjoins as
    select a.*,b.*
    from March a,Delay b
    where a.flight=b.flight and a.date=b.date;
quit;
我的问题还有合并完了新的数据集一个data也没有,这样不对。

使用道具

7
lvmuqu 发表于 2017-8-10 08:24:54 |只看作者 |坛友微信交流群
proc sql undo_policy=none;
        create table a as
                select a.* ,b.ANALYS ,b.value ,b.actual
                from a2 as a
                left join bt2 as b
                on a.permno=b.permno and a.analyst=b.analyst and a.forecastdate=b.forecastdate
        ;
quit;
已有 1 人评分经验 学术水平 热心指数 信用等级 收起 理由
阿扁V5 + 40 + 2 + 2 + 2 热心帮助其他会员

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

使用道具

8
阿扁V5 学生认证  发表于 2017-8-10 11:53:51 |只看作者 |坛友微信交流群
susanzhu 发表于 2017-8-6 23:58
为什么回复还要审核呢?
我是根据这个网页上推荐的程序写的:
http://blog.sina.com.cn/s/blog_5d3b177c0 ...
你要看march表和delay表中的是否有满足where条件的观测,如果没有就当然为空了

使用道具

9
ymf023 发表于 2017-8-10 21:32:29 |只看作者 |坛友微信交流群
两个数据集中有字段重名了,但对结果没有影响,可以忽略警告。
不过尽量不要用select *这个方式,要什么字段取什么字段。

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-25 13:22