SQL Query to get common records
I have a table as below ID Username GroupID 1 venkat 2 2 venkat 3 3 ramu 1 4 ramu 2 Using the sql statement I want to retrieve all username's that are available in both the groupids 2,3 In this case only Venkat is the username that's available in both groupid 2 and 3 Kindly help me Try this: SELECT userName FROM tableA WHERE groupId IN (2, 3) GROUP BY userName HAVING COUNT(DISTINCT groupId) = 2; Check the SQL FIDDLE DEMO OUTPUT | USERNAME | |----------| | venkat | An alternate approach using a plain JOIN ; SELECT DISTINCT t1.username FROM MyTable t1 JOIN MyTable t2 ON t1.username = t2.username