Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations gkittelson on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Comparing data within the same table

Status
Not open for further replies.

luvmy2Js

IS-IT--Management
Sep 1, 2010
43
US
I have a table that a set of data from 2 sources. The difference is the employeeid has letters in the front when coming from table b:

employee id [Pay Group ID]
WD506197 US01
506197 USA-1

Below is the code I have so far, but I am not sure how to distinguish the tables and if this is going to work:

Select
a.[employee id], a.[Pay Group ID],
'Analysis' = Case when a.[Pay Group ID] = b.[Pay Group ID] then ''
when a.[Pay Group ID] <> b.[Pay Group ID]
then 'MisMatch' end
from whse_AssignEmployeetoPayGroup a
inner join whse_AssignEmployeetoPayGroup b on b.[employee id] = a.[employee id]


I want something like this as the results:

employee id [Pay Group ID]
WD506197 'MisMatch'


Any help is greatly appreciated!
 
Thanks for the table, I should have used it instead of writing from the top of my head. Here is a working code

Code:
Select 
a.[employee id], a.[Pay Group ID],
'Analysis' ='MisMatch'  
from @Temp  a
LEFT join @Temp  b
on a.[Employee ID] = 'WD' + b.[Employee ID] and a.[Employee ID] like 'WD%' and a.[Pay Group ID] <> b.[Pay Group ID]
UNION 
Select 
a.[employee id], a.[Pay Group ID],
'Analysis' ='MisMatch'  
from @Temp  a
LEFT join @Temp  b
on b.[Employee ID] = 'WD' + a.[Employee ID] and b.[Employee ID] like 'WD%' and a.[Pay Group ID] <> b.[Pay Group ID]
order by [Employee Id]

PluralSight Learning Library
 
Try
Code:
;with cte as (Select 
a.[employee id], a.[Pay Group ID],
'Analysis' ='MisMatch'  
from @Temp  a
inner join @Temp  b
on a.[Employee ID] = 'WD' + b.[Employee ID] and a.[Employee ID] like 'WD%' and a.[Pay Group ID] <> b.[Pay Group ID]
UNION ALL
Select 
a.[employee id], a.[Pay Group ID],
'Analysis' ='No Match'  
from @Temp  a 
where not exists (select 1 from @Temp b
where a.[Employee Id] = 'WD' + b.[Employee Id])
and a.[Employee Id] LIKE 'WD%' 
--LEFT join @Temp  b
--on b.[Employee ID] = 'WD' + a.[Employee ID] and b.[Employee ID] like 'WD%' and a.[Pay Group ID] <> b.[Pay Group ID]
UNION ALL
Select 
a.[employee id], a.[Pay Group ID],
'Analysis' ='No Match'  
from @Temp  a 
where not exists (select 1 from @Temp b
where b.[Employee Id] = 'WD' + a.[Employee Id])
and a.[Employee Id] not LIKE 'WD%') 

select * from cte order by REPLACE([Employee ID],'WD','')



PluralSight Learning Library
 
What does the ";with cte as" mean? Never seen that before..

Thanks,
 
Thanks a million guys for all of your help on this!!
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top