<?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 First and Last in proc sql in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731316#M227801</link>
    <description>&lt;P&gt;Hello ,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am try to write code in Proc sql for below data step , but i am not getting as results in data step vs proc sql.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;My data step:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data last_ass_dt;
  set all_results;
  by usubjid rsdt;
  if first.usubjid;
keep usubjid rsdt;
run;

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;My testing proc sql code:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
   create table last_ass_dt as
   select usubjid,rsdt,'last Assesment date' as ByGroup
   from all_results a1
   where rsdt = (select min(rsdt)
                     from all_results a2
                     where a1.rsdt = a2.rsdtc)
  order by usubjid,rsdt;
quit;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;please let me know what i am missing in PROC SQL code.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you,&lt;/P&gt;&lt;P&gt;Raja.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Mon, 05 Apr 2021 05:59:32 GMT</pubDate>
    <dc:creator>raja777pharma</dc:creator>
    <dc:date>2021-04-05T05:59:32Z</dc:date>
    <item>
      <title>First and Last in proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731316#M227801</link>
      <description>&lt;P&gt;Hello ,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I am try to write code in Proc sql for below data step , but i am not getting as results in data step vs proc sql.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;My data step:&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data last_ass_dt;
  set all_results;
  by usubjid rsdt;
  if first.usubjid;
keep usubjid rsdt;
run;

&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;My testing proc sql code:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
   create table last_ass_dt as
   select usubjid,rsdt,'last Assesment date' as ByGroup
   from all_results a1
   where rsdt = (select min(rsdt)
                     from all_results a2
                     where a1.rsdt = a2.rsdtc)
  order by usubjid,rsdt;
quit;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;please let me know what i am missing in PROC SQL code.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Thank you,&lt;/P&gt;&lt;P&gt;Raja.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Mon, 05 Apr 2021 05:59:32 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731316#M227801</guid>
      <dc:creator>raja777pharma</dc:creator>
      <dc:date>2021-04-05T05:59:32Z</dc:date>
    </item>
    <item>
      <title>Re: First and Last in proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731317#M227802</link>
      <description>&lt;P&gt;Why not just do this in the Data Step? Seems much easier.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;However, try this (untested)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
   create table last_ass_dt as
   select usubjid, rsdt
   from all_results
   group by usubjid
   having min(rsdt) = rsdt;
quit;&lt;/CODE&gt;&lt;/PRE&gt;</description>
      <pubDate>Mon, 05 Apr 2021 06:23:03 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731317#M227802</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2021-04-05T06:23:03Z</dc:date>
    </item>
    <item>
      <title>Re: First and Last in proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731330#M227804</link>
      <description>&lt;BLOCKQUOTE&gt;&lt;HR /&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/31304"&gt;@PeterClemmensen&lt;/a&gt;&amp;nbsp;wrote:&lt;BR /&gt;
&lt;P&gt;Why not just do this in the Data Step? Seems much easier.&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;However, try this (untested)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
   create table last_ass_dt as
   select usubjid, rsdt
   from all_results
   group by usubjid
   having min(rsdt) = rsdt;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;HR /&gt;&lt;/BLOCKQUOTE&gt;
&lt;P&gt;MIN is not the same as first.variable (and I don't know if it works for character variables)&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;To &lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/309000"&gt;@raja777pharma&lt;/a&gt; , this is a feature that exists only in a DATA step, so you really need to use a DATA step. There is really no equivalent feature in SQL.&lt;/P&gt;</description>
      <pubDate>Mon, 05 Apr 2021 12:03:07 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731330#M227804</guid>
      <dc:creator>PaigeMiller</dc:creator>
      <dc:date>2021-04-05T12:03:07Z</dc:date>
    </item>
    <item>
      <title>Re: First and Last in proc sql</title>
      <link>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731381#M227822</link>
      <description>&lt;P&gt;SQL is based on SET operators and as such really doesn't have a native concept of "first" or "last" for values in a subset.&lt;/P&gt;
&lt;P&gt;If you did around the internet you will find that the order of records in a query can be seriously changed by code optimizers working in the background to make a query execute more efficiently.&lt;/P&gt;
&lt;P&gt;So if you get something that works one time for SQL it may not the next time with different data.&lt;/P&gt;</description>
      <pubDate>Mon, 05 Apr 2021 15:18:26 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/First-and-Last-in-proc-sql/m-p/731381#M227822</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2021-04-05T15:18:26Z</dc:date>
    </item>
  </channel>
</rss>

