Solved

help with tricky query.

Posted on 2015-02-11
3
47 Views
Last Modified: 2015-02-12
I need to compare Table_1 and Table_2.

Table_1 and Table_2 both have duplicate records. Table_2 has more duplicate records in it than table_1.
I need a list of all of the names in table_2 that are also in table_1. But I want the names of those in Table_2
that have more duplicate names in table_2. So for example, below both tables have Joseph Dreadson in them.


Table_2 has more records in it than Table_1.

I need a list of all of the names in Table_2 that have more records than their matching names in
Table_1.


So for these two tables :


Table_1
FNAME   LNAME
Bob     Candoiti
Mary    Semper
Mary    Semper
Mary    Semper
Joseph  Dreadson
Terry   James




Table_2
FNAME   LNAME
Bob     Candoiti
Mary    Semper
Mary    Semper
Joseph  Dreadson
Joseph  Dreadson
Joseph  Dreadson
Terry   James
Terry   James



So the desired query would return these two records, because these people occur more frequently in table_2 than table_1
 :

Joseph Deadson
Terry  James
0
Comment
Question by:brgdotnet
  • 2
3 Comments
 
LVL 48

Accepted Solution

by:
PortletPaul earned 500 total points
ID: 40605009
SELECT
       coalesce(t1.fname,t2.fname) as fname
     , coalesce(t1.lname,t2.lname) as lname
     , t1.count_t1
     , t2.count_t2
FROM (
            SELECT
                  fname
                , lname
                , COUNT(*) AS COUNT_t1
            FROM table_1
            GROUP BY
                  fname
                , lname
      ) T1
      FULL OUTER JOIN (
            SELECT
                  fname
                , lname
                , COUNT(*) AS COUNT_t2
            FROM table_2
            GROUP BY
                  fname
                , lname
      ) T2 ON T1.fname = T2.fname
      AND T1.lname = T2.lname
WHERE T2.count_t2 > T1.count_t1
;

Open in new window


|  FNAME |    LNAME | COUNT_T1 | COUNT_T2 |
|--------|----------|----------|----------|
| Joseph | Dreadson |        1 |        3 |
|  Terry |    James |        1 |        2 |

Open in new window

0
 
LVL 2

Author Closing Comment

by:brgdotnet
ID: 40607335
Awesome!
0
 
LVL 48

Expert Comment

by:PortletPaul
ID: 40607386
WHERE T2.count_t2 > T1.count_t1
OR T1.count_t1 IS NULL
OR T2.count_t1 IS NULL

it may need to cater for NULLs which I forgot
0

Featured Post

Optimizing Cloud Backup for Low Bandwidth

With cloud storage prices going down a growing number of SMBs start to use it for backup storage. Unfortunately, business data volume rarely fits the average Internet speed. This article provides an overview of main Internet speed challenges and reveals backup best practices.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

When you hear the word proxy, you may become apprehensive. This article will help you to understand Proxy and when it is useful. Let's talk Proxy for SQL Server. (Not in terms of Internet access.) Typically, you'll run into this type of problem w…
Introduction SQL Server Integration Services can read XML files, that’s known by every BI developer.  (If you didn’t, don’t worry, I’m aiming this article at newcomers as well.) But how far can you go?  When does the XML Source component become …
Familiarize people with the process of utilizing SQL Server functions from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Ac…
Via a live example combined with referencing Books Online, show some of the information that can be extracted from the Catalog Views in SQL Server.

932 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now