BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
bhca60
Quartz | Level 8

I am trying to do a CASE WHEN with a date filter. I need to add new criteria from 5/6/2024 onward - the new criteria is that we're looking at los >= 20 days instead of rpm_score=.13.  I need to keep the rpm_score=.13 but it should only apply to admdt on or before 5/5/2024.  How do I update this WHEN statement to reflect the new criteria and keep the old criteria so I can use them all in the same WHEN statement? 

        select a.*,b.CMS_ID as HPLAN,
             case
                 when a.RPM_Score >= 0.13 and admdt <="05may2024"d  then 1 
	         when a.los>= 20 and admdt >= "06may2024"d then 1 
		else 0

 

1 ACCEPTED SOLUTION

Accepted Solutions
Tom
Super User Tom
Super User

I cannot tell from your description what you want.  Providing example input data with the expected result would help a lot to clarify (and you will probably answer your own question just be going through the process of making the example data).

 

I suspect you wnat to NEST the CASE clauses.

case when missing(admdt) then .
     when admdt <="05may2024"d then
          case when a.RPM_Score >= 0.13 then 1 else 0 end
     else case when a.RPM_Score >= 0.20 then 1 else 0 end
end

View solution in original post

4 REPLIES 4
PaigeMiller
Diamond | Level 26

Ok, I don't see what is wrong with the code you are showing. (Why does everything have to be in the same WHEN statement?)

Is there an error message? If so show us the log for this PROC SQL (all the lines in the log for PROC SQL, not just the lines with the error). Are you getting incorrect output? If so, please provide (a portion of) the input data and show us the incorrect output.

--
Paige Miller
Tom
Super User Tom
Super User

I cannot tell from your description what you want.  Providing example input data with the expected result would help a lot to clarify (and you will probably answer your own question just be going through the process of making the example data).

 

I suspect you wnat to NEST the CASE clauses.

case when missing(admdt) then .
     when admdt <="05may2024"d then
          case when a.RPM_Score >= 0.13 then 1 else 0 end
     else case when a.RPM_Score >= 0.20 then 1 else 0 end
end
bhca60
Quartz | Level 8
yes except for the last case when it would be los >= 20 then 1 else 0. Thank you!!
bhca60
Quartz | Level 8
If i wanted to include another date filter such as admtdt >="06may2024"d for when the days_total >=20 (instead of rpm_score >=0.20), where would I put that?

sas-innovate-white.png

Special offer for SAS Communities members

Save $250 on SAS Innovate and get a free advance copy of the new SAS For Dummies book! Use the code "SASforDummies" to register. Don't miss out, May 6-9, in Orlando, Florida.

 

View the full agenda.

Register now!

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