SAS中文论坛

 找回密码
 立即注册

扫一扫,访问微社区

查看: 693|回复: 3
打印 上一主题 下一主题

请教一个proc sql 中count的问题,在线等

[复制链接]

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
楼主
 楼主| 发表于 2010-3-23 10:52:23 | 只看该作者

请教一个proc sql 中count的问题,在线等

程序:
proc sql;
create table trdays
(stkcd char(6), trday num);
%macro trad(stkcd, year);
select count(*) into :count
from resdat.dret
where stkcd="&stkcd" and year(date)=&year;
insert into trdays(stkcd,trdays) values("&stkcd", &count);
%mend;
%trad(000001,1999);
quit;

ERROR: VALUES 子句1的值2不匹配对象项列表中相应列的数据类型(在Select子句中)。
ERROR:以下这些列在起作用的表中没有找到:trdays.
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
沙发
 楼主| 发表于 2010-3-23 11:33:12 | 只看该作者

Re: 请教一个proc sql 中count的问题,在线等

变量名不统一, TRDAY or TRDAYS
[quote="fan":31djnnx6]......
(stkcd char(6), [color=#FF0000:31djnnx6]trday[/color:31djnnx6] num);
......
insert into trdays(stkcd,[color=#FF0000:31djnnx6]trdays[/color:31djnnx6]) values("&stkcd", &count);
......[/quote:31djnnx6]
PS:为了看着清晰宏定义最好写在sql的外面;调用宏在语法上是不需要以分号结束的
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
板凳
 楼主| 发表于 2010-3-23 11:40:09 | 只看该作者

Re: 请教一个proc sql 中count的问题,在线等

thank somuch~
回复 支持 反对

使用道具 举报

49

主题

76

帖子

1462

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
1462
地板
 楼主| 发表于 2010-3-23 12:11:23 | 只看该作者

Re: 请教一个proc sql 中count的问题,在线等

把sql都放在macro里不行吗?
[code:1yifqyr0]%macro trad(stkcd,year);
        proc sql;
                create table trdays as
                        select stkcd,count(*) as trday
                                from dret
                                where stkcd="&stkcd" and year(date)=&year
                                group by stkcd;
        quit;
%mend;

%trad(000001,1999)[/code:1yifqyr0]
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|小黑屋|手机版|Archiver|SAS中文论坛  

GMT+8, 2026-3-3 15:51 , Processed in 0.106261 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表