<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Send an email once even if no data exists but after that do not send an email if no data exists in New SAS User</title>
    <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549228#M8640</link>
    <description>&lt;P&gt;thank you...i was thinking about the time of day as well....will have a look at that.&lt;/P&gt;</description>
    <pubDate>Mon, 08 Apr 2019 12:07:41 GMT</pubDate>
    <dc:creator>sophie07</dc:creator>
    <dc:date>2019-04-08T12:07:41Z</dc:date>
    <item>
      <title>Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549211#M8635</link>
      <description>&lt;P&gt;I'm not sure how to explain this. I'm currently running a script to see which items have updated in a report. There is a column named "updated" which is set to 'Yes' if it has updated and 'No' if its not. i am required to send an email out every day with a full report which i attach in an email using SAS. the script is kicked off every 30 minutes. What i'm trying to do is add a check to say if there are no records for updated = 'No' then no email should send out. the problem is i still need to send out an initial email once a day.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;this is what i'm using for my check:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;i would like to schedule&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;%macro check();&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;proc sql noprint;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;select count(*) into: chk&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;from mydata;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;quit;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;%IF &amp;amp;CHK &amp;gt; 0 %THEN %DO;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&lt;BR /&gt;&lt;/SPAN&gt;proc export data=work.mydata&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; outfile='D:\folder\test\mydata.csv'&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; dbms = csv replace;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; delimiter=';' ;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;run;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&lt;SPAN&gt;&lt;BR /&gt;&lt;/SPAN&gt;&lt;SPAN&gt;filename mymail email "&lt;/SPAN&gt;&lt;A href="mailto:me.me@email.com" target="_blank" rel="nofollow noopener noreferrer"&gt;me.me@email.com&lt;/A&gt;&lt;SPAN&gt;"&lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;subject="My Mail to You"&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;attach='D:\folder\test\mydata.csv';&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; data _null_;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; file mymail;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;run;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;%END;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;%mend check;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;%check();&amp;nbsp;&amp;nbsp;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 08 Apr 2019 10:37:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549211#M8635</guid>
      <dc:creator>sophie07</dc:creator>
      <dc:date>2019-04-08T10:37:57Z</dc:date>
    </item>
    <item>
      <title>Re: Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549216#M8636</link>
      <description>&lt;P&gt;The current proc sql checks for observations not regarding the value of "updated". The following step should fix that issue:&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql noprint;
  select count(*) into: chk trimmed
    from mydata
      where updated = 'YES'
  ;
quit&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;For the other issue (always send the first e-mail) you need something to identify the first run of the day. Maybe the time of day could be used. If can't identify the first run that way, you need to save a trigger outside the sas session.&lt;/P&gt;</description>
      <pubDate>Mon, 08 Apr 2019 11:28:29 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549216#M8636</guid>
      <dc:creator>andreas_lds</dc:creator>
      <dc:date>2019-04-08T11:28:29Z</dc:date>
    </item>
    <item>
      <title>Re: Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549228#M8640</link>
      <description>&lt;P&gt;thank you...i was thinking about the time of day as well....will have a look at that.&lt;/P&gt;</description>
      <pubDate>Mon, 08 Apr 2019 12:07:41 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549228#M8640</guid>
      <dc:creator>sophie07</dc:creator>
      <dc:date>2019-04-08T12:07:41Z</dc:date>
    </item>
    <item>
      <title>Re: Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549231#M8641</link>
      <description>&lt;P&gt;sorry im not that familiar with sas...how would i put the time of day as a check? lets say it needs to send out the full email at 8am, after that it should only send out an email if there are any updated = 'No'&lt;/P&gt;</description>
      <pubDate>Mon, 08 Apr 2019 12:11:25 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/549231#M8641</guid>
      <dc:creator>sophie07</dc:creator>
      <dc:date>2019-04-08T12:11:25Z</dc:date>
    </item>
    <item>
      <title>Re: Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/550501#M8811</link>
      <description>&lt;P&gt;The datastep-function time() returns the current time as number of seconds since midnight, formats are used to display those values in an easy to read way. The documentation has examples: &lt;A href="https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=lefunctionsref&amp;amp;docsetTarget=p096aldg7bq6qsn10m4044qbslka.htm" target="_blank"&gt;https://documentation.sas.com/?cdcId=pgmsascdc&amp;amp;cdcVersion=9.4_3.4&amp;amp;docsetId=lefunctionsref&amp;amp;docsetTarget=p096aldg7bq6qsn10m4044qbslka.htm&lt;/A&gt;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;Time-constants (8 am in your case) are written like this '08:00't. So in a data step you can do:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;if time() = '08:00't then do;
  /* what ever is to be done */
end;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Unfortunately this will hardly ever work as expected, because it has to exactly 8 am - zero minutes, seconds and even milliseconds - and it is hardly possible to schedule a job, so that it execute that piece of code exatly at that time. But as you said: "the script is kicked off every 30 minutes.", the following code should solve the issue:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;%local firstRun;

data _null_;
   t = time();

   if '08:00't &amp;lt;= t &amp;lt; '08:30't then do;
      call symputx('firstRun', 'yes');
   end;
   else do;
      call symputx('firstRun', 'no');
   end;
run;


%local chk;
/* add code setting the variable chk here */


/* no quotes in macro code! */
%if &amp;amp;chk. &amp;gt; 0 %then %do;
   %put NOTE: Sending normal mail;
   /* normal send code */
%end;
%else %do;
   %if &amp;amp;firstRun. = yes %then %do;
     /* code to send the first mail, even if nothing was updated */
   %put NOTE: Sending first mail without updates;
   %end;
%end;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;One final note: starting with macro-programming without being familiar with the fundamental concepts of the sas language seems to be not the best basis for solving problems.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 12 Apr 2019 05:19:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/550501#M8811</guid>
      <dc:creator>andreas_lds</dc:creator>
      <dc:date>2019-04-12T05:19:01Z</dc:date>
    </item>
    <item>
      <title>Re: Send an email once even if no data exists but after that do not send an email if no data exists</title>
      <link>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/550511#M8812</link>
      <description>&lt;P&gt;Thank you so much!&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;yes i know, unfortunately this was handed down to me from a predecessor and i am just trying to get it to work as expected.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;i appreciate all the help&lt;/P&gt;</description>
      <pubDate>Fri, 12 Apr 2019 07:06:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/New-SAS-User/Send-an-email-once-even-if-no-data-exists-but-after-that-do-not/m-p/550511#M8812</guid>
      <dc:creator>sophie07</dc:creator>
      <dc:date>2019-04-12T07:06:32Z</dc:date>
    </item>
  </channel>
</rss>

