<?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: Multiple lookup on Same Hash Table - using Macros in SAS Data Management</title>
    <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/482149#M15030</link>
    <description>&lt;P&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/221594"&gt;@jpm2478&lt;/a&gt;&lt;/P&gt;
&lt;P&gt;If you're after fully working code then start by providing representative sample data for everything - and provide this sample data in form of tested SAS data steps so we've got something to start with.&lt;/P&gt;
&lt;P&gt;Then explain in detail the problem you have to solve - one step at a time.&lt;/P&gt;
&lt;P&gt;May be break up the problem into steps, give it a first go and come back here asking questions for the things you get stuck with - and also post the code you've already developed.&lt;/P&gt;</description>
    <pubDate>Sat, 28 Jul 2018 03:49:15 GMT</pubDate>
    <dc:creator>Patrick</dc:creator>
    <dc:date>2018-07-28T03:49:15Z</dc:date>
    <item>
      <title>Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481844#M15022</link>
      <description>&lt;P&gt;Hi,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;I have a big dataset (A) of patients containing millions of rows and 50 columns. I need to do Multiple Hash lookups of the table using Macros. For example, I have patient info below by Patient Id.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Loc&lt;/TD&gt;&lt;TD&gt;HQ&lt;/TD&gt;&lt;TD&gt;Inv&lt;/TD&gt;&lt;TD&gt;Fill_Loc&lt;/TD&gt;&lt;TD&gt;Fill_Qty&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;STL&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;500&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1099&lt;/TD&gt;&lt;TD&gt;PIT&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;STL&lt;/TD&gt;&lt;TD&gt;110&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MCI&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;120&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;ORI&lt;/TD&gt;&lt;TD&gt;110&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1059&lt;/TD&gt;&lt;TD&gt;CDL&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;TD&gt;MCI&lt;/TD&gt;&lt;TD&gt;0&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;HOW&lt;/TD&gt;&lt;TD&gt;HIT&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2045&lt;/TD&gt;&lt;TD&gt;IND&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;MCI&lt;/TD&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;MRD&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;TD&gt;IND&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;ORL&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;TD&gt;LTY&lt;/TD&gt;&lt;TD&gt;80&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;STK&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;5&lt;/TD&gt;&lt;TD&gt;ORF&lt;/TD&gt;&lt;TD&gt;40&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&lt;BR /&gt;1. I need to do Hash lookup on Pt_Id and Fill_Loc. For example, Pt_Id, Fill_Loc&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Fill_Loc&lt;/TD&gt;&lt;TD&gt;Fill_Qty&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;2. Using the result from 1, I need to do look-up on Pt_id and &lt;U&gt;Fill_loc from 1 will become HQ&lt;/U&gt;.....&amp;nbsp;&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;HQ&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;3.&amp;nbsp; From 1, Patient No. 1058 had a Fill_Qty of 100. From 2, I need to lookup Pt_Id, HQ and get Inv. If Fill_Qty was 100 then I need to show Inv of 100.&amp;nbsp;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Loc&lt;/TD&gt;&lt;TD&gt;Inv&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MCI&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;4. &lt;U&gt;The total Inv should not be more them Fill_Qty.&lt;/U&gt; If Inv. was more then Fill_Qty then I need to check each record and reduce the last record so that the total will be equal to Fill_Qty.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Below is another example where Inv was more than Fill_Qty and I'll adjust the last inv. record to be equal to Fill_Qty.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;1. Lookup&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Fill_Loc&lt;/TD&gt;&lt;TD&gt;Fill_Qty&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;4&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;2.&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;HQ&lt;/TD&gt;&lt;TD&gt;Inv&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;&lt;U&gt;5&lt;/U&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;3. Result - Total of Inv. = Fill_Qty&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;HQ&lt;/TD&gt;&lt;TD&gt;Inv&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;1&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;2&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;2051&lt;/TD&gt;&lt;TD&gt;IAD&lt;/TD&gt;&lt;TD&gt;&lt;U&gt;1&lt;/U&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;The last row was adjusted from 5 to 1 so that the total of Inv matches Fill_Qty.&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jul 2018 13:11:06 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481844#M15022</guid>
      <dc:creator>jpm2478</dc:creator>
      <dc:date>2018-07-27T13:11:06Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481847#M15023</link>
      <description>&lt;P&gt;Could you please supply (as a first example) the complete result (all observations, all variables) for patient 1058?&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jul 2018 13:18:34 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481847#M15023</guid>
      <dc:creator>Kurt_Bremser</dc:creator>
      <dc:date>2018-07-27T13:18:34Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481868#M15024</link>
      <description>&lt;P&gt;So, just to get things started, here is the first part (1).&lt;/P&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data have;
input Pt_Id $ Loc $ HQ $ Inv Fill_Loc $ Fill_Qty;
datalines;
1058 STL ORD 500 MEM 100
1099 PIT MEM 50 STL 110
1058 MCI MEM 50 ORD 120
1058 ORD MEM 50 ORI 110
1059 CDL IAD 100 MCI 0
2051 HOW HIT 100 IAD 4
2045 IND IAD 5 MCI 5
2051 MRD IAD 1 IND 50
2051 ORL IAD 2 LTY 80
2051 STK IAD 5 ORF 40
;

data want;
   length Fill_Qty 8;
   if _N_ = 1 then do;
      declare hash h(dataset:"have");
      h.defineKey('Pt_Id','Fill_Loc');
      h.defineData('Fill_Qty');
      h.defineDone();
      call missing(Fill_Qty);
   end;

   Pt_Id="1058";Fill_Loc="MEM";

   h.find();
run;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Next: From question 2: "&lt;U&gt;Fill_loc from 1 will become HQ"..&lt;/U&gt; I don't understand that? Please elaborate&lt;/P&gt;</description>
      <pubDate>Fri, 27 Jul 2018 14:02:28 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481868#M15024</guid>
      <dc:creator>PeterClemmensen</dc:creator>
      <dc:date>2018-07-27T14:02:28Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481871#M15025</link>
      <description>&lt;P&gt;Here is the full dataset for 1058.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Loc&lt;/TD&gt;&lt;TD&gt;HQ&lt;/TD&gt;&lt;TD&gt;Inv&lt;/TD&gt;&lt;TD&gt;Fill_Loc&lt;/TD&gt;&lt;TD&gt;Fill_Qty&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;STL&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;500&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;100&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MCI&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;120&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;ORD&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;50&lt;/TD&gt;&lt;TD&gt;ORI&lt;/TD&gt;&lt;TD&gt;110&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;FIT&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;10&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;TD&gt;10&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Fri, 27 Jul 2018 14:06:26 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481871#M15025</guid>
      <dc:creator>jpm2478</dc:creator>
      <dc:date>2018-07-27T14:06:26Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481873#M15026</link>
      <description>&lt;P&gt;You cannot hard code Pt_id and Fill_Loc. It is basically a loop. In the first run it is looking for 1058 and MEM Second run it will look for 1099 and STl and so on.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;Coming to your question about &lt;U&gt;Fill_Location will be HQ&lt;/U&gt; ....So, the Ist lookup is Pt_id and Fill_Loc. Now, the output has to be looked up under Pt_id and HQ.....MEM has to be filtered under Variable HQ.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;Fill_Loc&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;TABLE border="0" cellspacing="0" cellpadding="0"&gt;&lt;TBODY&gt;&lt;TR&gt;&lt;TD&gt;Pt_Id&lt;/TD&gt;&lt;TD&gt;&lt;U&gt;HQ&lt;/U&gt;&lt;/TD&gt;&lt;/TR&gt;&lt;TR&gt;&lt;TD&gt;1058&lt;/TD&gt;&lt;TD&gt;MEM&lt;/TD&gt;&lt;/TR&gt;&lt;/TBODY&gt;&lt;/TABLE&gt;</description>
      <pubDate>Fri, 27 Jul 2018 14:15:49 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481873#M15026</guid>
      <dc:creator>jpm2478</dc:creator>
      <dc:date>2018-07-27T14:15:49Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481939#M15027</link>
      <description>Any suggestions?</description>
      <pubDate>Fri, 27 Jul 2018 17:02:01 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/481939#M15027</guid>
      <dc:creator>jpm2478</dc:creator>
      <dc:date>2018-07-27T17:02:01Z</dc:date>
    </item>
    <item>
      <title>Re: Multiple lookup on Same Hash Table - using Macros</title>
      <link>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/482149#M15030</link>
      <description>&lt;P&gt;&lt;a href="https://communities.sas.com/t5/user/viewprofilepage/user-id/221594"&gt;@jpm2478&lt;/a&gt;&lt;/P&gt;
&lt;P&gt;If you're after fully working code then start by providing representative sample data for everything - and provide this sample data in form of tested SAS data steps so we've got something to start with.&lt;/P&gt;
&lt;P&gt;Then explain in detail the problem you have to solve - one step at a time.&lt;/P&gt;
&lt;P&gt;May be break up the problem into steps, give it a first go and come back here asking questions for the things you get stuck with - and also post the code you've already developed.&lt;/P&gt;</description>
      <pubDate>Sat, 28 Jul 2018 03:49:15 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Data-Management/Multiple-lookup-on-Same-Hash-Table-using-Macros/m-p/482149#M15030</guid>
      <dc:creator>Patrick</dc:creator>
      <dc:date>2018-07-28T03:49:15Z</dc:date>
    </item>
  </channel>
</rss>

