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

Hi,

    I'm running below PROC SQL with range of dates in where clause giving issue.

   I'm trying to pull this data from oracle DB.

  

(t3.FILE_DATE_OF_REPORT BETWEEN input("&Start_Date",date9.) AND input("&End_Date",date9.)

               AND t2.SENDER_NAME LIKE 'SDI %'))

Somebody help me what was issue?

Thanks,

rk.

1 ACCEPTED SOLUTION

Accepted Solutions
DF
Fluorite | Level 6 DF
Fluorite | Level 6

It's probably better in the later versions of SAS, but certainly in 9.1.3 this could cause difficulties as SAS would end up processing the entire table as Oracle won't recognise the meaning of datepart.

I would normally try to send it datetimes instead, which should also allow it to use any indexes etc. on the table.  For example change your query to:

BETWEEN input("&Start_Date.:00:00:00",datetime20.) AND input("&End_Date.:23:59:59",datetime20.)

This article has some interesting notes on this: http://www.sascommunity.org/wiki/SAS_with_Oracle:_Writing_Efficient_and_Accurate_SQL

View solution in original post

6 REPLIES 6
art297
Opal | Level 21

Oracle dates, I believe, are actually datetime fields.  Take a look at: http://www.nesug.org/proceedings/nesug04/io/io04.pdf

Ksharp
Super User

I am not sure whether it wolud be work .just a guess.

Assuming FILE_DATE_OF_REPORT is datetime. format.

(datepart(t3.FILE_DATE_OF_REPORT) BETWEEN  "&Start_Date"d  AND "&End_Date"d)

               AND t2.SENDER_NAME LIKE 'SDI %'))

Ksharp

DF
Fluorite | Level 6 DF
Fluorite | Level 6

It's probably better in the later versions of SAS, but certainly in 9.1.3 this could cause difficulties as SAS would end up processing the entire table as Oracle won't recognise the meaning of datepart.

I would normally try to send it datetimes instead, which should also allow it to use any indexes etc. on the table.  For example change your query to:

BETWEEN input("&Start_Date.:00:00:00",datetime20.) AND input("&End_Date.:23:59:59",datetime20.)

This article has some interesting notes on this: http://www.sascommunity.org/wiki/SAS_with_Oracle:_Writing_Efficient_and_Accurate_SQL

sasg
Calcite | Level 5

Hi DF,

If i hardcode date like datetime format it's working....is it gonna work with your logic.

It's a very big query....taking two hours to pull the data....so i would like to confirm before running.

WHERE (t1.RECEIVED_FILE_ID = t3.RECEIVED_FILE_ID AND t2.FILE_SENDER_ID = t3.FILE_SENDER_ID AND

      t1.CLD_PATIENT_COOKED_ID = t4.CLD_PATIENT_COOKED_ID AND t1.CLD_PATIENT_COOKED_ID =t5.CLD_PATIENT_COOKED_ID)AND

      ('1Jan2010:0:0:0'dt <= t3.FILE_DATE_OF_REPORT <= '25Aug2011:0:0:0'dt

       AND t2.SENDER_NAME LIKE 'SDI %'))

Thanks,

rk.

 

FriedEgg
SAS Employee

using the ''dt will convert your text date to a sas numeric date value which may not correctly represent the same date in your oracle machine.

%let startdate=01jan2010;

%let enddate=31dec2010;

data _null_;

call symput('start', "'" || "&startdate.:00:00:00" || "'");

call symput('end', "'" || "&enddate.:00:00:00" || "'");

run;

proc sql;

/* stuff */

&start <= t3.file_date_of_report <= &end

/* otherstuff */

quit;

sasg
Calcite | Level 5

Thanks all.....it worked.

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

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
  • 6 replies
  • 2082 views
  • 0 likes
  • 5 in conversation