<?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: Using in= while setting 2 datasets in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394218#M94970</link>
    <description>&lt;P&gt;You are&amp;nbsp;&lt;U&gt;&lt;STRONG&gt;setting&lt;/STRONG&gt;&lt;/U&gt; the data work.people first then afterwards money, therefore the logic if insal and inemp can never be true as both rows never appear on the same row. &amp;nbsp;Perhaps you meant to merge the two datasets:&lt;/P&gt;
&lt;PRE class=" language-sas"&gt;&lt;CODE class="  language-sas"&gt;&lt;SPAN class="token procnames"&gt;data&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;empsalary&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="token keyword"&gt;  merge&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;people &lt;SPAN class="token punctuation"&gt;(&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;in&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt;inemp&lt;SPAN class="token punctuation"&gt;)&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;money &lt;SPAN class="token punctuation"&gt;(&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;in&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt;insal&lt;SPAN class="token punctuation"&gt;)&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;;&lt;BR /&gt;&lt;/SPAN&gt;  by name;
&lt;SPAN class="token keyword"&gt;  if&lt;/SPAN&gt; insal and inemp&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="token procnames"&gt;run&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Note, both have to be sorted by name first.&amp;nbsp;&lt;/P&gt;</description>
    <pubDate>Fri, 08 Sep 2017 14:30:16 GMT</pubDate>
    <dc:creator>RW9</dc:creator>
    <dc:date>2017-09-08T14:30:16Z</dc:date>
    <item>
      <title>Using in= while setting 2 datasets</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394215#M94967</link>
      <description>&lt;P&gt;I have used the following code:&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data people;
input obs name$;
cards;
1 Frank
2 Joan
3 Sui
4 Jose
5 Burt
6 Kelly
7 Juan
;
run;
data money;
input name$ sal;
cards;
Frank 100
Joan 210
Sui 250
Jose 330
;
run;

data work.empsalary;
set work.people (in = inemp) work.money (in = insal);
if insal and inemp;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;How can the observations be 0 when there are common variables in both sets. can anyone explain it to me.&lt;/P&gt;&lt;P&gt;Thanks.&lt;/P&gt;</description>
      <pubDate>Fri, 08 Sep 2017 14:05:04 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394215#M94967</guid>
      <dc:creator>ab12nov</dc:creator>
      <dc:date>2017-09-08T14:05:04Z</dc:date>
    </item>
    <item>
      <title>Re: Using in= while setting 2 datasets</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394218#M94970</link>
      <description>&lt;P&gt;You are&amp;nbsp;&lt;U&gt;&lt;STRONG&gt;setting&lt;/STRONG&gt;&lt;/U&gt; the data work.people first then afterwards money, therefore the logic if insal and inemp can never be true as both rows never appear on the same row. &amp;nbsp;Perhaps you meant to merge the two datasets:&lt;/P&gt;
&lt;PRE class=" language-sas"&gt;&lt;CODE class="  language-sas"&gt;&lt;SPAN class="token procnames"&gt;data&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;empsalary&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="token keyword"&gt;  merge&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;people &lt;SPAN class="token punctuation"&gt;(&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;in&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt;inemp&lt;SPAN class="token punctuation"&gt;)&lt;/SPAN&gt; work&lt;SPAN class="token punctuation"&gt;.&lt;/SPAN&gt;money &lt;SPAN class="token punctuation"&gt;(&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;in&lt;/SPAN&gt;&lt;SPAN class="token operator"&gt;=&lt;/SPAN&gt;insal&lt;SPAN class="token punctuation"&gt;)&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;;&lt;BR /&gt;&lt;/SPAN&gt;  by name;
&lt;SPAN class="token keyword"&gt;  if&lt;/SPAN&gt; insal and inemp&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;
&lt;SPAN class="token procnames"&gt;run&lt;/SPAN&gt;&lt;SPAN class="token punctuation"&gt;;&lt;/SPAN&gt;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Note, both have to be sorted by name first.&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 08 Sep 2017 14:30:16 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394218#M94970</guid>
      <dc:creator>RW9</dc:creator>
      <dc:date>2017-09-08T14:30:16Z</dc:date>
    </item>
    <item>
      <title>Re: Using in= while setting 2 datasets</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394220#M94971</link>
      <description>&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;data people;
input obs name$;
cards;
1 Frank
2 Joan
3 Sui
4 Jose
5 Burt
6 Kelly
7 Juan
;
run;
proc sort data = &amp;amp;syslast;by name;

PROC sql; describe table &amp;amp;syslast;quit;
data money;
input name$ sal;
cards;
Frank 100
Joan 210
Sui 250
Jose 330
;
run;
proc sort data = &amp;amp;syslast;by name;

PROC sql; describe table &amp;amp;syslast;quit;

data work.empsalary;
merge work.people (in = inemp) work.money (in = insal);
by name;
if insal and inemp then output;
run;
PROC sql; describe table &amp;amp;syslast;quit;
proc print;
run;&lt;/CODE&gt;&lt;/PRE&gt;&lt;P&gt;the set statement stacks the output&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;use merge+by instead, which requires data attribute says it is sorted,&lt;/P&gt;&lt;P&gt;even though the data in alpha order by name.&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;&lt;P&gt;hth&lt;/P&gt;&lt;P&gt;Ron Fehd&amp;nbsp; data structure mostly, sometimes algorithm maven&lt;/P&gt;&lt;P&gt;&amp;nbsp;&lt;/P&gt;</description>
      <pubDate>Fri, 08 Sep 2017 14:34:43 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Using-in-while-setting-2-datasets/m-p/394220#M94971</guid>
      <dc:creator>Ron_MacroMaven</dc:creator>
      <dc:date>2017-09-08T14:34:43Z</dc:date>
    </item>
  </channel>
</rss>

