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

Hi, I wanted to count events on dates using count() in proc sql. Here is the sample code:

data have0;
 infile cards truncover expandtabs;
 input ID $ CODE DATE :date9. DEPT $ ;
 format date date8. ;
 cards;
A0001 7001 12Oct2015 ETA 
A0001 7002 12Oct2015 ETA 
A0001 7001 12Nov2015 ETA 
A0001 7001 15Nov2016 ETA 
A0001 7002 13Oct2016 ETB 
A0001 7003 13Oct2015 ETB 

A0002 7001 12Oct2015 ETA  
A0002 7002 12Oct2015 ETA  
A0002 7003 12Oct2015 ETA  
A0002 7001 20Oct2016 ETB  
A0002 7002 23Oct2016 ETB  
A0002 7003 30Nov2016 ETB  

;
run;

PROC SQL;
   CREATE TABLE events_ct AS
   SELECT 
		count(*) as line_cnt
        ,count(distinct ID) as ID_cnt
		,count(distinct CODE) as CODE_cnt
		,count(distinct case when DEPT="ETA" then CODE end) as EtA_CODE_cnt
		,count(case when DEPT="ETA" then DATE end) as events_cnt
      FROM have0
;
QUIT;

The results for events_cnt shoud be 3 because I want to count the total distinct dates for each ID.

 

What I need actually is something like this:

count(distinct case when DEPT="ETA" then (DATE from have0 group by ID) end) as events_cnt

but this code doesn't work as it is now. It there any solution to modify the count(case when DEPT="ETA" then DATE end) as events_cnt and get what I need? Thanks a lot ! 

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
ChrisNZ
Tourmaline | Level 20

This counts what you want:

  count(unique case when DEPT="ETA" then cats(DATE,CODE) end) -1 as EVENTS_CNT

You need to substract 1 as an empty string will also be counted when DEPT <> 'ETA'

 

View solution in original post

11 REPLIES 11
leehsin
Quartz | Level 8
Correction: I meant "The results for events_cnt should be 4 because I want to count the total distinct dates for each ID."
Reeza
Super User
Add a GROUP BY clause to tell SAS to process it by specific groups.

GROUP BY ID is what you need.

leehsin
Quartz | Level 8
Where do I put GROUP BY ID? I don't want to put it after FROM Have0 as this will affect other COUNT statements.
Reeza
Super User
In that case that won't work and you need either a subquery or do multiple queries and combine the results. I would probably recommending the second option - do your queries separately and merge them for clarity. It's easier to manage your analysis in this fashion.
PGStats
Opal | Level 21

Please provide an example showing all the different counts that you want to perform, including expected results.

PG
leehsin
Quartz | Level 8

These are the 4 records I want to count:

 

 A0001 12Oct2015 ETA
A0001 12Nov2015 ETA
A0001 15Nov2016 ETA
A0002 12Oct2015 ETA

Tom
Super User Tom
Super User

@leehsin wrote:

These are the 4 records I want to count:

 

 A0001 12Oct2015 ETA
A0001 12Nov2015 ETA
A0001 15Nov2016 ETA
A0002 12Oct2015 ETA


That does NOT look like counts.

What are the counts you want for the 12 observations in your example dataset.

leehsin
Quartz | Level 8
I meant these are the 4 records to be counted, ---- 3 different dates for A0001, and 1 different date for A0002.
ChrisNZ
Tourmaline | Level 20

This counts what you want:

  count(unique case when DEPT="ETA" then cats(DATE,CODE) end) -1 as EVENTS_CNT

You need to substract 1 as an empty string will also be counted when DEPT <> 'ETA'

 

leehsin
Quartz | Level 8

Thank you, ChrisNZ! This is the solution I am looking for.

 

I just change 'CODE' to 'ID' as I want to group the count of dates by ID.

count(unique case when DEPT="ETA" then cats(DATE,ID) end) as EVENTS_CNT

The result to have:

lin_cnt  ID_cnt  CODE_cnt  EtA_CODE_cnt  envents_cnt

        13         2                 3                         3                    4

Tom
Super User Tom
Super User

Are you looking for something like this?

proc sql;
create table want as
select id
     , count(*) as line_cnt
     , count(distinct code) as code_cnt
     , count(distinct date) as date_cnt
     , count(distinct dept) as dept_cnt
     , count(case when dept='ETA' then 1 end) as eta_cnt
     , count(distinct case when dept='ETA' then code end) as eta_code_cnt
     , count(distinct case when dept='ETA' then date end) as eta_date_cnt
     , count(distinct case when dept='ETA' then dept end) as eta_dept_cnt
from have
group by id
;
quit;
                                                               eta_      eta_      eta_
Obs   ID    line_cnt  code_cnt  date_cnt  dept_cnt  eta_cnt  code_cnt  date_cnt  dept_cnt

 1   A0001      6         3         5         2        4         2         3        1
 2   A0002      6         3         4         2        3         3         1        1

SAS Innovate 2025: Call for Content

Are you ready for the spotlight? We're accepting content ideas for SAS Innovate 2025 to be held May 6-9 in Orlando, FL. The call is open until September 16. Read more here about why you should contribute and what is in it for you!

Submit your idea!

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.

Click image to register for webinarClick image to register for webinar

Classroom Training Available!

Select SAS Training centers are offering in-person courses. View upcoming courses for:

View all other training opportunities.

Discussion stats
  • 11 replies
  • 1225 views
  • 1 like
  • 5 in conversation