楼主: dxystata
1776 5

proc sql出错 [推广有奖]

版主

大师

34%

还不是VIP/贵宾

-

TA的文库  其他...

Software

中英文Ebook

R学习

威望
2
论坛币
182303 个
通用积分
15205.6089
学术水平
208 点
热心指数
271 点
信用等级
174 点
经验
291306 点
帖子
5378
精华
1
在线时间
13479 小时
注册时间
2006-6-21
最后登录
2024-4-28

初级学术勋章 初级热心勋章 中级热心勋章 初级信用勋章

30论坛币
%let nby=4;
proc sql 中
select count(*) into: pp1-:pp&nby


标红的有空格出错,谢谢!

最佳答案

不是吧258123 查看完整内容

%let nby=4; proc sql 中 select count(*) into: pp1-:pp%sysfunc(left(&nby)) 就可以了
关键词:proc sql ROC sql Select Elect count
沙发
不是吧258123 发表于 2016-12-7 22:03:31 |只看作者 |坛友微信交流群
%let nby=4;
proc sql 中
select count(*) into: pp1-:pp%sysfunc(left(&nby))  
就可以了

使用道具

藤椅
hplcdadong 发表于 2016-12-7 23:38:20 |只看作者 |坛友微信交流群
Possible reason:
select count(*) only generate one number, you could not put it into multiple macro variables.

   If you really want to store this count number into a macro variable, you could :

                            proc sql;
                            select count(*) into: pp
                            from ...

    If you, for example , want to store the first 4 unique IDs into 4 different macros, you could:
                           
                             %let nby=4;
                             proc sql noprint;
                             select distinct id into: pp1 - :pp&nby
                             from ...


已有 1 人评分经验 学术水平 热心指数 收起 理由
dxystata + 100 + 1 + 1 热心帮助其他会员

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

使用道具

板凳
dxystata 发表于 2016-12-8 09:44:55 |只看作者 |坛友微信交流群
pp 4 估计是空格的原因,如何实现比较好呢

使用道具

报纸
hszest 学生认证  发表于 2016-12-8 10:05:05 |只看作者 |坛友微信交流群
INTO: 要建立宏变量,宏变量命名不能包含空格啊,替换成下划线不行吗?

使用道具

dxystata 发表于 2016-12-8 09:44
pp 4 估计是空格的原因,如何实现比较好呢
试试加一句%let nby=&nby;呢
已有 1 人评分经验 学术水平 热心指数 收起 理由
dxystata + 100 + 1 + 1 精彩帖子

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

使用道具

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

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

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

GMT+8, 2024-4-28 07:29