BookmarkSubscribeRSS Feed
🔒 This topic is solved and locked. Need further help from the community? Please sign in and ask a new question.
ngrannum75
Fluorite | Level 6

Hi, I am trying to perform a full join using two tables, there is no output on the log; my SAS server just seems to be timing out. Not sure what is happening or how to troubleshoot this issue. Here is my code.

 

%LET start_date = 01JAN20:12:00: 00.000000;
proc sql;
create table uat as
select x.sku_id, x.Base_Price_Amt, xx.On_Air_Qty,
y.Shipping_And_Handling_Amt, y.Source_Cd
from hist x full join expos y on (x.sku_id = y.sku_id)
where x.Valid_Start_Dttm between "&start_date."d and today() - 1
;
quit;

1 ACCEPTED SOLUTION

Accepted Solutions
Tom
Super User Tom
Super User

Dates are stored as the number of DAYS since 1960. Datetimes are stored as the number of SECONDS since 1960.  So unless your DATETIME values are very early in the date 01JAN1960 they will never be between any two DATE values.

 

Use a DATETIME literal by appending DT instead of just D to the quoted string that the DATETIME informat can interpret.  Make sure to use a DATETIME value for the upper bound of your interval also.

where x.Valid_Start_Dttm BETWEEN "&start_date."dt AND intnx('dtday',datetime(),-1)

Or since it appears you don't really care about the time of day part of the datetime variable, convert it from seconds to days.

where datepart(x.Valid_Start_Dttm) BETWEEN datepart("&start_date."dt) AND today()-1

On source of confusion is that SAS is not going to throw an error when you give it extra characters in your date literal.  So SAS will happily treat these two things as the same number of days without any error or warning.

"01JAN2020:12:00:00.000000"d
"01JAN2020"d

View solution in original post

4 REPLIES 4
ngrannum75
Fluorite | Level 6

Thank you. 

I am new to SAS EG. How do you suggest I correct this variable? In the table uses this datetime format and i would like to filter for a specific date range. is my macro incorrect or my where clause? 

 

Valid_Start_Dttm 

"01JAN2020:12:00:00.000000"d

 

%LET start_date = 01JAN2020:12:00:00.000000;

 

where x.Valid_Start_Dttm BETWEEN "&start_date."d AND TODAY()- 1;

 

I am guessing I would need a datetime in my where clause? 

 

 

Thank you. 

Tom
Super User Tom
Super User

Dates are stored as the number of DAYS since 1960. Datetimes are stored as the number of SECONDS since 1960.  So unless your DATETIME values are very early in the date 01JAN1960 they will never be between any two DATE values.

 

Use a DATETIME literal by appending DT instead of just D to the quoted string that the DATETIME informat can interpret.  Make sure to use a DATETIME value for the upper bound of your interval also.

where x.Valid_Start_Dttm BETWEEN "&start_date."dt AND intnx('dtday',datetime(),-1)

Or since it appears you don't really care about the time of day part of the datetime variable, convert it from seconds to days.

where datepart(x.Valid_Start_Dttm) BETWEEN datepart("&start_date."dt) AND today()-1

On source of confusion is that SAS is not going to throw an error when you give it extra characters in your date literal.  So SAS will happily treat these two things as the same number of days without any error or warning.

"01JAN2020:12:00:00.000000"d
"01JAN2020"d
ngrannum75
Fluorite | Level 6
Thank you so much! This clears up my confusion!

sas-innovate-wordmark-2025-midnight.png

Register Today!

Join us for SAS Innovate 2025, our biggest and most exciting global event of the year, in Orlando, FL, from May 6-9. Sign up by March 14 for just $795.


Register now!

How to Concatenate Values

Learn how use the CAT functions in SAS to join values from multiple variables into a single value.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 4 replies
  • 1447 views
  • 2 likes
  • 3 in conversation