Ask the Expert

Tips for derived tables in SQL and using FULL OUTER JOINs

My question is regarding FULL OUTER JOINs on derived tables. My query is as follows:

select tb1.usr,tb1.ADD,tb2.UPD from
(select usr,count(nin) ADD   
from RGS8 where act='ADD' 
and dte=20080310 group by usr)  tb1 
FULL OUTER JOIN
(select usr,count(nin) UPD   
from RGS8 where act='UPD' 
and dte=20080310 group by usr)  tb2 
ON tb1.usr=tb2.usr

The query executes successfully when using the left or the right outer joins but no results are given with the full outer joins. I wonder if there are some constraints with FULL OUTER JOINs?

    Requires Free Membership to View

I'm not sure why it isn't working for you, unless perhaps you're using MySQL, which doesn't support FULL OUTER JOIN. But in that case you should've received an error message, rather than no results.

Here's an alternate strategy:

SELECT usr
     , SUM(CASE WHEN act = 'ADD'
                THEN 1
                ELSE 0 END) AS ADD
     , SUM(CASE WHEN act = 'UPD'
                THEN 1
                ELSE 0 END) AS UPD
  FROM RGS8 
 WHERE act IN ('ADD','UPD') 
   AND dte = 20080310 
GROUP 
    BY usr

This should perform better as well, since it requires only one pass of the table.

This was first published in October 2008

There are Comments. Add yours.

 
TIP: Want to include a code block in your comment? Use <pre> or <code> tags around the desired text. Ex: <code>insert code</code>

REGISTER or login:

Forgot Password?
By submitting you agree to receive email from TechTarget and its partners. If you reside outside of the United States, you consent to having your personal data transferred to and processed in the United States. Privacy
Sort by: OldestNewest

Forgot Password?

No problem! Submit your e-mail address below. We'll send you an email containing your password.

Your password has been sent to: