<?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: Need help with Joining Multiple Tabels in SAS Procedures</title>
    <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14077#M2164</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Assuming that employee_ID is a unique key to all three datasets, you could start with something like this :&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select A.Employee_Name, P.Employee_Hire_Date, coalesce(A2.Employee_Name,"Unknown") as Manager_Name&lt;/P&gt;&lt;P&gt;from orion.Employee_Addresses AS A inner join orion.Employee_Payroll as P on A.Employee_ID=P.Employee_ID &lt;/P&gt;&lt;P&gt;inner join orion.Employee_Organization as O on A.Employee_ID=O.Employee_ID&lt;/P&gt;&lt;P&gt;left join orion.Employee_Addresses AS A2 on O.Manager_ID=A2.Employee_ID;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;the key here is referencing Employee_Addresses&lt;STRONG&gt; twice &lt;/STRONG&gt;in the query&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;PG&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Sat, 25 Feb 2012 21:31:21 GMT</pubDate>
    <dc:creator>PGStats</dc:creator>
    <dc:date>2012-02-25T21:31:21Z</dc:date>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14074#M2161</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Hello Everyone,&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt; I am having some problems with this program that I am working on for my Advanced SAS studies.&lt;/P&gt;&lt;P&gt; I need to create a report that displays the employee's name, their years of service, and the employee manager's name.&lt;/P&gt;&lt;P&gt; I have three tables I need to combine:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;orion.Employee_Addresses contains&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Employee_Name&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;orion.Employee_Payroll contains&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Employee_Hire_Date&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;orion.Employee_Organization contains&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp; * Manager_ID (Employee_ID of the person's manager which is also the same as their Employee_ID)&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I've gotten this code so far:&lt;/P&gt;&lt;P&gt;libname orion 'C:\SAS\'; * Creating libref Orion;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;title1 'Employees with more than 30 years of service';&lt;/P&gt;&lt;P&gt;title2 'as of December 31, 2007';&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; select a.Employee_Name, int(('31DEC2007'd-p.Employee_Hire_Date)/365.25) as YOS label='Years of Service'&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; from orion.Employee_Addresses as a,&lt;/P&gt;&lt;P&gt;&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; orion.Employee_Payroll as p&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; where calculated YOS&amp;gt;30;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;This is the query that I have to identify the managers:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; select distinct a.Employee_Name,a.Employee_ID,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; from orion.Employee_Addresses as a,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; orion.Employee_Organization as o&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; where a.Employee_ID=o.Manager_ID;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;I combined the two to get this query:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;title1 'Employees with more than 30 years of service';&lt;/P&gt;&lt;P&gt;title2 'as of December 31, 2007';&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; select distinct a.Employee_Name,int(('31DEC2007'd-p.Employee_Hire_Date)/365.25) as YOS label='Years of Service',&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Manager_Name.Employee_Name as ManagerName label = 'Manager Name'&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; from orion.Employee_Addresses as a,&lt;/P&gt;&lt;P&gt;&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; orion.Employee_Payroll as p,&lt;/P&gt;&lt;P&gt;&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; (select a.Employee_Name&lt;/P&gt;&lt;P&gt;&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; from orion.Employee_Addresses as a,&lt;/P&gt;&lt;P&gt;&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; orion.Employee_Organization as o&lt;/P&gt;&lt;P&gt;&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; where a.Employee_ID=o.Manager_ID) as Manager_Name&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; having YOS&amp;gt;30&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp; order by ManagerName, YOS desc,Employee_Name;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;But now it is not filtering to the 71 employees that I want and pulling every employee and saying that they have greater than 30 years of service.&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Could someone give me a little help with this?&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Thanks!&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Alisa&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 20:40:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14074#M2161</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-25T20:40:24Z</dc:date>
    </item>
    <item>
      <title>Re: Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14075#M2162</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;A question for you:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Are there multiple records for any Employee_IDs in any of the three files and, if so, which one do you want?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 20:48:10 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14075#M2162</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2012-02-25T20:48:10Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14076#M2163</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I just posted an update to this, and I just need the one that is associated with the Employee_Addresses data set.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 21:08:58 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14076#M2163</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-25T21:08:58Z</dc:date>
    </item>
    <item>
      <title>Re: Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14077#M2164</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Assuming that employee_ID is a unique key to all three datasets, you could start with something like this :&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;select A.Employee_Name, P.Employee_Hire_Date, coalesce(A2.Employee_Name,"Unknown") as Manager_Name&lt;/P&gt;&lt;P&gt;from orion.Employee_Addresses AS A inner join orion.Employee_Payroll as P on A.Employee_ID=P.Employee_ID &lt;/P&gt;&lt;P&gt;inner join orion.Employee_Organization as O on A.Employee_ID=O.Employee_ID&lt;/P&gt;&lt;P&gt;left join orion.Employee_Addresses AS A2 on O.Manager_ID=A2.Employee_ID;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;the key here is referencing Employee_Addresses&lt;STRONG&gt; twice &lt;/STRONG&gt;in the query&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;PG&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 21:31:21 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14077#M2164</guid>
      <dc:creator>PGStats</dc:creator>
      <dc:date>2012-02-25T21:31:21Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14078#M2165</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Wouldn't it be easier to do an inline query instead of using all of those joins?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 21:45:19 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14078#M2165</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-25T21:45:19Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14079#M2166</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;I'm not SQLsavvy enough to answer your last question.&amp;nbsp; Regardless, the only thing (other than a quit statement) that you would have to add to PGStats suggested code, in order to get what you wanted, is the part about years of service.&amp;nbsp; i.e.:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;&amp;nbsp; select A.Employee_Name, P.Employee_Hire_Date format=date0.,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; int(('31DEC2007'd-p.Employee_Hire_Date)/365.25)&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; as YOS label='Years of Service',&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; coalesce(A2.Employee_Name,"Unknown") as Manager_Name&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; from orion.Employee_Addresses AS A&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; inner join orion.Employee_Payroll as P&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; on A.Employee_ID=P.Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; inner join orion.Employee_Organization as O&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; on A.Employee_ID=O.Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; left join orion.Employee_Addresses AS A2&lt;/P&gt;&lt;P&gt;&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; on O.Manager_ID=A2.Employee_ID&lt;/P&gt;&lt;P&gt;&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; having calculated YOS&amp;gt;30&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;quit;&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 22:04:25 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14079#M2166</guid>
      <dc:creator>art297</dc:creator>
      <dc:date>2012-02-25T22:04:25Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14080#M2167</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks so much!! :smileylaugh:&lt;/P&gt;&lt;P&gt;Could you explain to me why it was better to use the joins instead of doing an inline query?&lt;/P&gt;&lt;P&gt;Also, why did you use coalesce as a part of the query?&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 22:23:51 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14080#M2167</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-25T22:23:51Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14081#M2168</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Could you also explain to me why you used coalese in your query?&lt;/P&gt;&lt;P&gt;Thanks again for your help!!:smileylaugh:&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 22:26:24 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14081#M2168</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-25T22:26:24Z</dc:date>
    </item>
    <item>
      <title>Re: Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14082#M2169</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;You might get slightly better marks with the query :&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;proc sql;&lt;/P&gt;&lt;P&gt;&amp;nbsp; select A.Employee_Name, P.Employee_Hire_Date format=date0.,&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; INTCK("YEAR", P.Employee_Hire_Date, "31DEC2007"d, "CONTINUOUS")&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; as YOS label='Years of Service',&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; coalesce(A2.Employee_Name, "Unknown") as Manager_Name&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; from orion.Employee_Addresses AS A&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; inner join orion.Employee_Payroll as P&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; on A.Employee_ID=P.Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; inner join orion.Employee_Organization as O&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; on A.Employee_ID=O.Employee_ID&lt;/P&gt;&lt;P&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; left join orion.Employee_Addresses AS A2&lt;/P&gt;&lt;P&gt;&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; on O.Manager_ID=A2.Employee_ID&lt;/P&gt;&lt;P&gt;&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; where calculated YOS &amp;gt; 30&lt;/P&gt;&lt;P&gt;;&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;Explanations:&lt;/P&gt;&lt;P&gt;&lt;/P&gt;&lt;UL&gt;&lt;LI&gt;I find it preferable to do explicit joins when &lt;STRONG&gt;inner joins&lt;/STRONG&gt; are combined with &lt;STRONG&gt;left joins&lt;/STRONG&gt; which cannot be specified as implicit joins (with simple where conditions). In any case, explicit joins require almost the same amount of typing as implicit joins &lt;img id="smileyhappy" class="emoticon emoticon-smileyhappy" src="https://communities.sas.com/i/smilies/16x16_smiley-happy.png" alt="Smiley Happy" title="Smiley Happy" /&gt;. &lt;/LI&gt;&lt;LI&gt;The coalesce function takes care of the cases where the left join doesnt find the employee's manager. In a hierartical list like that, it is obvious that the "top" manager will not have anyone listed as his/her manager. The coalesce takes care of that case.&lt;/LI&gt;&lt;LI&gt;I replaced the HAVING clause with a WHERE clause because the HAVING clause is meant to be applied to the result of aggregation functions. In some SQL parsers, HAVING clauses are not even accepted without a GROUP BY clause.&lt;/LI&gt;&lt;LI&gt;The INTCK function will calculate the exact years of service (your calculation was probably good enough for most purposes but it wasn't &lt;STRONG&gt;exact &lt;img id="smileywink" class="emoticon emoticon-smileywink" src="https://communities.sas.com/i/smilies/16x16_smiley-wink.png" alt="Smiley Wink" title="Smiley Wink" /&gt;&lt;/STRONG&gt;). Check the function's documentation. &lt;/LI&gt;&lt;/UL&gt;&lt;P&gt;&lt;/P&gt;&lt;P&gt;PG&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 25 Feb 2012 23:30:57 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14082#M2169</guid>
      <dc:creator>PGStats</dc:creator>
      <dc:date>2012-02-25T23:30:57Z</dc:date>
    </item>
    <item>
      <title>Need help with Joining Multiple Tabels</title>
      <link>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14083#M2170</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;P&gt;Thanks so much your help and explanations. I am studying for this stuff on my own as part of my senior project in college, so it is hard when all I have is a book and some PowerPoint slides to help get me through.&lt;/P&gt;&lt;P&gt;I would have never thought of doing inner and left joins for this problem. I was just trying to brute force it with inline queries.&lt;/P&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sun, 26 Feb 2012 00:17:33 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Procedures/Need-help-with-Joining-Multiple-Tabels/m-p/14083#M2170</guid>
      <dc:creator>InfoAlisaA</dc:creator>
      <dc:date>2012-02-26T00:17:33Z</dc:date>
    </item>
  </channel>
</rss>

