<?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 aggregate values in one row per primary key in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185860#M265613</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;vHi,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'd like to change the dataset&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;From&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" width="192"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD height="20" width="64"&gt;Acct&lt;/TD&gt;&lt;TD width="64"&gt;mail date&lt;/TD&gt;&lt;TD width="64"&gt;Order&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Feb&lt;/TD&gt;&lt;TD align="right"&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Mar&lt;/TD&gt;&lt;TD align="right"&gt;3&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Apr&lt;/TD&gt;&lt;TD align="right"&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;To&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" width="256"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD height="20" width="64"&gt;Acct&lt;/TD&gt;&lt;TD width="64"&gt;Order 1&lt;/TD&gt;&lt;TD width="64"&gt;Order 2&lt;/TD&gt;&lt;TD width="64"&gt;Order 3&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Feb&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Mar&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Apr&lt;/TD&gt;&lt;TD&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;How can I do this in SAS?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Kwang&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Fri, 18 Apr 2014 17:33:57 GMT</pubDate>
    <dc:creator>kyoo</dc:creator>
    <dc:date>2014-04-18T17:33:57Z</dc:date>
    <item>
      <title>aggregate values in one row per primary key</title>
      <link>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185860#M265613</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;vHi,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I'd like to change the dataset&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;From&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" width="192"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD height="20" width="64"&gt;Acct&lt;/TD&gt;&lt;TD width="64"&gt;mail date&lt;/TD&gt;&lt;TD width="64"&gt;Order&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Feb&lt;/TD&gt;&lt;TD align="right"&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Mar&lt;/TD&gt;&lt;TD align="right"&gt;3&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right"&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl63"&gt;1-Apr&lt;/TD&gt;&lt;TD align="right"&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;To&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;TABLE border="0" cellpadding="0" cellspacing="0" width="256"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD height="20" width="64"&gt;Acct&lt;/TD&gt;&lt;TD width="64"&gt;Order 1&lt;/TD&gt;&lt;TD width="64"&gt;Order 2&lt;/TD&gt;&lt;TD width="64"&gt;Order 3&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;111&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Feb&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Mar&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD align="right" height="20"&gt;222&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Jan&lt;/TD&gt;&lt;TD align="right" class="xl65"&gt;1-Apr&lt;/TD&gt;&lt;TD&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;How can I do this in SAS?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks,&lt;/P&gt;&lt;P&gt;Kwang&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 18 Apr 2014 17:33:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185860#M265613</guid>
      <dc:creator>kyoo</dc:creator>
      <dc:date>2014-04-18T17:33:57Z</dc:date>
    </item>
    <item>
      <title>Re: aggregate values in one row per primary key</title>
      <link>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185861#M265614</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;You can do it with the following program.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;data kyoo;&lt;/P&gt;&lt;P&gt;input Acct maildate$ Order;&lt;/P&gt;&lt;P&gt;cards;&lt;/P&gt;&lt;P&gt;111 1-Jan 1&lt;/P&gt;&lt;P&gt;111 1-Feb 2&lt;/P&gt;&lt;P&gt;111 1-Mar 3&lt;/P&gt;&lt;P&gt;222 1-Jan 1&lt;/P&gt;&lt;P&gt;222 1-Apr 2&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;proc transpose data=b;&lt;/P&gt;&lt;P&gt;var maildate;&lt;/P&gt;&lt;P&gt;by acct;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 18 Apr 2014 17:48:38 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185861#M265614</guid>
      <dc:creator>zana</dc:creator>
      <dc:date>2014-04-18T17:48:38Z</dc:date>
    </item>
    <item>
      <title>Re: aggregate values in one row per primary key</title>
      <link>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185862#M265615</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;If the order is always sequential it isn't even needed.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;SPAN style="font-size: 8pt;"&gt;&amp;nbsp; &lt;/SPAN&gt;&lt;/P&gt;&lt;P&gt;data have;&lt;/P&gt;&lt;P&gt;input Acct maildate $ Order ;&lt;/P&gt;&lt;P&gt;datalines;&lt;/P&gt;&lt;P&gt;111 1-Jan 1&lt;/P&gt;&lt;P&gt;111 1-Feb 2&lt;/P&gt;&lt;P&gt;111 1-Mar 3&lt;/P&gt;&lt;P&gt;222 1-Jan 1&lt;/P&gt;&lt;P&gt;222 1-Apr 2&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;/* assumes data is sorted by acct and order number*/&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc transpose data=have out=want (drop=_name_)&lt;/P&gt;&lt;P&gt;prefix=order&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;by acct;&lt;/P&gt;&lt;P&gt;var maildate;&lt;/P&gt;&lt;P&gt;run;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Fri, 18 Apr 2014 17:52:39 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185862#M265615</guid>
      <dc:creator>ballardw</dc:creator>
      <dc:date>2014-04-18T17:52:39Z</dc:date>
    </item>
    <item>
      <title>Re: aggregate values in one row per primary key</title>
      <link>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185863#M265616</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hi Kyoo,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Proc transpose would work fine for your data. But what if the data is like this...&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;111 1-Jan 1 &lt;/P&gt;&lt;P&gt;111 1-Feb 3 &lt;/P&gt;&lt;P&gt;111 1-Mar 4 &lt;/P&gt;&lt;P&gt;222 1-Jan 1 &lt;/P&gt;&lt;P&gt;222 1-Apr 3&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Order2 will not be included in your output. For this u have to go with data step as given below,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;DATA HAVE;&lt;BR /&gt;INPUT Acct mail_date $ Order;&lt;BR /&gt;DATALINES; &lt;BR /&gt;111 1-Jan 1 &lt;BR /&gt;111 1-Feb 3 &lt;BR /&gt;111 1-Mar 4 &lt;BR /&gt;222 1-Jan 1 &lt;BR /&gt;222 1-Apr 3&lt;BR /&gt;;&lt;BR /&gt;RUN;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;*Selecting the maximum of order;&lt;/P&gt;&lt;P&gt;PROC SQL NOPRINT;&lt;BR /&gt;SELECT MAX(ORDER) INTO :M_ORD FROM HAVE ;&lt;BR /&gt;QUIT;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;PROC SORT DATA=HAVE;&lt;BR /&gt;BY ACCT;&lt;BR /&gt;RUN;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;DATA WANT(DROP=ORD MAIL_DATE I);&lt;BR /&gt;SET HAVE (RENAME=(ORDER=ORD));&lt;BR /&gt;ARRAY ORDER(&amp;amp;M_ORD) $&amp;nbsp; ;&lt;BR /&gt;BY ACCT;&lt;BR /&gt;RETAIN ORDER: ;&lt;BR /&gt;IF FIRST.ACCT THEN &lt;BR /&gt;DO I = 1 TO &amp;amp;M_ORD;&lt;BR /&gt;ORDER(I)=" ";&lt;BR /&gt;END;&lt;BR /&gt;ORDER(ORD)= MAIL_DATE;&lt;BR /&gt;IF LAST.ACCT;&lt;BR /&gt;RUN;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Mon, 21 Apr 2014 05:23:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/aggregate-values-in-one-row-per-primary-key/m-p/185863#M265616</guid>
      <dc:creator>SKK</dc:creator>
      <dc:date>2014-04-21T05:23:15Z</dc:date>
    </item>
  </channel>
</rss>

