[mysql] MySQL에서 중복 레코드 찾기

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;


답변

SELECT date FROM logs group by date having count(*) >= 2


답변

INNER가 왜 테이블 자체에 참여하지 않습니까?

SELECT a.firstname, a.lastname, a.address
FROM list a
INNER JOIN list b ON a.address = b.address
WHERE a.id <> b.id

주소가 두 번 이상 존재할 수 있으면 DISTINCT가 필요합니다.


답변

이 질문에 선택된 최선의 답변을 시도했지만 다소 혼란 스럽습니다. 나는 실제로 내 테이블의 단일 필드에서만 필요했습니다. 이 링크 의 다음 예제는 저에게 매우 효과적이었습니다.

SELECT COUNT(*) c,title FROM `data` GROUP BY title HAVING c > 1;


답변

select `cityname` from `codcities` group by `cityname` having count(*)>=2

이것은 당신이 요청한 것과 비슷한 쿼리이며 200 % 작동하고 쉽습니다. 즐겨!!!


답변

쉽지 않습니까?

SELECT *
FROM tc_tariff_groups
GROUP BY group_id
HAVING COUNT(group_id) >1

?


답변

이 검색어 로 이메일 주소 로 중복 된 사용자 찾기 …

SELECT users.name, users.uid, users.mail, from_unixtime(created)
FROM users
INNER JOIN (
  SELECT mail
  FROM users
  GROUP BY mail
  HAVING count(mail) > 1
) dupes ON users.mail = dupes.mail
ORDER BY users.mail;