BookmarkSubscribeRSS Feed
ealderm2
Calcite | Level 5

I'm trying to merge 2 data sets. One has many rows with a date and the other has 3 rows and a data range with the aplicable value that i need to be picked up.

I need to show the correct value for each row in a by picking up the correct value within the date range specified.

I have tried the following -

proc sql;

create table work.EDW_ALL as
select *
from EDW_PLUS_CPC a
left join DCA_PERCENT b
ON a.DEALER_CODE=b.dealer_code
and A.CPC=B.CPC
AND  A.DLR_IP=B.DLR_IP
and PURCHASE_DATE >= CPA_START_DT
AND PURCHASE_DATE <= CPA_EXP_DT
;
QUIT;

This gives me all the 225 rows I need but only gives me the merged value when the date falls into the first range on the b dataset,

and

data work.EDW_ALL;

merge      EDW_PLUS_CPC (in=a)

  DCA_PERCENT (in=b);

by DEALER_CODE CPC DLR_IP;

if (PURCHASE_DATE >= CPA_START_DT

AND PURCHASE_DATE <= CPA_EXP_DT);

if a then

  output work.EDW_ALL;

run

This gives me just 10 rows where the date falls into the first range on the b dataset.

It would appear that the first row is being picked up rather than picking up the correct value for each date/row.

Any thoughts would be gratefully appreciated.

Thanks


2 REPLIES 2
Steelers_In_DC
Barite | Level 11

Do you get the desired results using a where clause in the second example?  Depending on where the data comes from you can do this:

dca_percent(in=b where=(PURCHASE_DATE >= CPA_START_DT AND PURCHASE_DATE <= CPA_EXP_DT));

JayCorbett
Calcite | Level 5

Could you post some sample data? Is the "Applicable Value" variable the same or different in the two data sets?

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

Creating Custom Steps in SAS Studio

Check out this tutorial series to learn how to build your own steps in SAS Studio.

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
  • 2 replies
  • 1487 views
  • 0 likes
  • 3 in conversation