全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
545 2
2023-01-19
悬赏 50 个论坛币 已解决
data _null_;
today=today();
year=year(today);
this_week=week(today)-1;
call symput( 'currentyear', year);
call symput('this_week', this_week);
run;


proc sql;

   connect to oracle as oracle_tables

      (user = USERID  orapw = PASSWORD  path ="INSTANCE");

      create table test as

      select * from connection to oracle_tables

      (select  * from abc.table

           where complete_year in (&currentyear)

                      and complete_week in (&this_week));

   disconnect from oracle_tables;

quit;


表中包含很多列,都需要通过pass through facility拿到。日期方面包括详细完成的日期,年份,星期等。我现在想到的方法可以拿到上一周的周日到周六的所有交易,但是一旦跨年了就有个小bug,每年第一周的时候this_week=0,会报错。悬赏看下大家怎么制作周度报表,尤其是怎么解决一周两三天在上一年,其它三四天在新年。


最佳答案

HXAI102230 查看完整内容

增加下面一句在“this_week=week(today)-1;“之后可以实现吗? if week=0 then do; year=year(today)-1; this_week=week(mdy(12,31,year)); end;
二维码

扫码加我 拉你入群

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

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

全部回复
2023-1-19 06:44:21
此帖仅作者可见
二维码

扫码加我 拉你入群

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

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

2023-1-19 11:06:44
此帖仅作者可见
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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