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

Is there a technique that will help me to identify new customers on a monthly basis?

Here is the example.

For Jan-2016 there are 5 new customers (1001, 1002, 1003, 1004 & 1005)

For Feb-2016 there are 8 customers, 3 are from Jan and 5 new customers (2001 to 2005)

For Mar-2016 there are 10 customers, however, 5 of them are already giving business from Jan/Feb. There are 5 new customers.

 

Is there a method that I can use to flag new suctomers for each month?

 

Customer_ID Month Used Service
1001 Jan-16 Y
1002 Jan-16 Y
1003 Jan-16 Y
1004 Jan-16 Y
1005 Jan-16 Y
1001 Feb-16 Y
1002 Feb-16 Y
1003 Feb-16 Y
2001 Feb-16 Y
2002 Feb-16 Y
2003 Feb-16 Y
2004 Feb-16 Y
2005 Feb-16 Y
1001 Mar-16 Y
1002 Mar-16 Y
1003 Mar-16 Y
2001 Mar-16 Y
2002 Mar-16 Y
3001 Mar-16 Y
3002 Mar-16 Y
3003 Mar-16 Y
3004 Mar-16 Y
3005 Mar-16 Y

 

Thanks,

+Sathyan

1 ACCEPTED SOLUTION

Accepted Solutions
RW9
Diamond | Level 26 RW9
Diamond | Level 26

Its useful to post your test data in the form of a datastep, so we can run it and see how the data is stored.  I am going to assume that month is a SAS date format.  Something like this, I haven't tested

proc sql;
  create table WANT as
  select   *
  from     HAVE
  group by CUSTOMER_ID
  having  MONTH=min(MONTH);
quit;

View solution in original post

3 REPLIES 3
RW9
Diamond | Level 26 RW9
Diamond | Level 26

Its useful to post your test data in the form of a datastep, so we can run it and see how the data is stored.  I am going to assume that month is a SAS date format.  Something like this, I haven't tested

proc sql;
  create table WANT as
  select   *
  from     HAVE
  group by CUSTOMER_ID
  having  MONTH=min(MONTH);
quit;
skallamp
Obsidian | Level 7

Thanks a lot.

Ksharp
Super User
data have;
infile cards expandtabs;
input Customer_ID	Month $;
cards;
1001	Jan-16	
1002	Jan-16	
1003	Jan-16	
1004	Jan-16	
1005	Jan-16	
1001	Feb-16	
1002	Feb-16	
1003	Feb-16	
2001	Feb-16	
2002	Feb-16	
2003	Feb-16	
2004	Feb-16	
2005	Feb-16	
1001	Mar-16	
1002	Mar-16	
1003	Mar-16	
2001	Mar-16	
2002	Mar-16	
3001	Mar-16	
3002	Mar-16	
3003	Mar-16	
3004	Mar-16	
3005	Mar-16
;
run;
data want;
 if _n_=1 then do;
  if 0 then set have;
  declare hash h();
  h.definekey('Customer_ID');
  h.definedone();
 end;
set have;
if h.check()=0 then New_Customer='N';
 else do;New_Customer='Y';h.add();end;
run;

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