반응형
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
반응형
'MySql' 카테고리의 다른 글
MySQL Mysql delete with subquery (0) | 2020.09.25 |
---|---|
MySQL foreach 루프에서 SQL 결과 사용 (0) | 2020.09.25 |
MySQL NOW ()에서 레코드 선택 -1 일 (0) | 2020.09.25 |
MySQL로 쉼표를 자르시겠습니까? (0) | 2020.09.25 |
MySQL InnoDB로 테이블을 MyISAM으로 변환하는 가장 안전한 방법은 무엇입니까? (0) | 2020.09.25 |
댓글