본문 바로가기
MySql

MySQL에서 중복 레코드 찾기

by 베이스 공부 2020. 9. 25.
반응형

MySQL 데이터베이스에서 중복 레코드를 꺼내고 싶습니다. 이것은 다음으로 수행 할 수 있습니다.

SELECT address, count(id) as cnt FROM list
GROUP BY address HAVING cnt > 1

결과 :

100 MAIN ST    2

중복 된 각 행을 표시하도록 끌어오고 싶습니다. 다음과 같은 것 :

JIM    JONES    100 MAIN ST
JOHN   SMITH    100 MAIN ST

이것이 어떻게 할 수 있는지에 대한 생각이 있습니까? 첫 번째 작업을 피하고 코드에서 두 번째 쿼리로 중복 항목을 찾는 것을 피하려고합니다.

 

해결 방법

 

핵심은 하위 쿼리로 사용할 수 있도록이 쿼리를 다시 작성하는 것입니다.

SELECT firstname, 
   lastname, 
   list.address 
FROM list
   INNER JOIN (SELECT address
               FROM   list
               GROUP  BY address
               HAVING COUNT(id) > 1) dup
           ON list.address = dup.address;

 

참조 페이지 https://stackoverflow.com/questions/854128

 

 

반응형

댓글