1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다."/> 1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다.">

>데이터 베이스 >MySQL 튜토리얼 >SQL에서 중복 데이터를 삭제하는 방법

SQL에서 중복 데이터를 삭제하는 방법

醉折花枝作酒筹
醉折花枝作酒筹원래의
2021-05-11 17:10:4838868검색

SQL에서는 select 문을 사용하여 중복 데이터를 삭제할 수 있습니다. 구문은 "필드 ID가 있는 필드에서 * 선택(개수(필드 ID) > 1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다.

SQL에서 중복 데이터를 삭제하는 방법

이 튜토리얼의 운영 환경: Windows 7 시스템, mysql 버전 8.0, Dell G3 컴퓨터.

SQL 문을 사용하여 중복 항목을 삭제하고 하나만 유지합니다.

수천 개의 레코드 중에 동일한 레코드가 몇 개 있습니다. SQL 문을 사용하여 중복 항목을 삭제하려면 어떻게 해야 할까요?

테이블에서 중복된 레코드를 찾아보세요. 단일 필드(peopleId) 기준

select * from people 
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1)

확장자:

테이블에서 중복된 레코드를 삭제합니다. 중복 레코드는 단일 필드(peopleId)를 기준으로 판단하고 가장 작은 rowid를 가진 레코드만 남깁니다.

delete from people
where   peopleName in (select peopleName    from people group by peopleName      having count(peopleName) > 1)
and   peopleId not in (select min(peopleId) from people group by peopleName     having count(peopleName)>1)

찾기 테이블에서 중복된 중복 레코드(다중 필드)

select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)

테이블에서 중복된 중복 레코드(다중 필드)를 삭제하고 rowid가 가장 작은 레코드만 남깁니다.

delete from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)

테이블에서 중복된 중복 레코드(다중 필드)를 찾아도 삭제되지 않습니다. 가장 작은 rowid를 가진 레코드 포함

select * from vitae a
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1)
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)

필드 왼쪽의 첫 번째 숫자 제거:

update tableName set [Title]=Right([Title],(len([Title])-1)) where Title like '村%'

필드 오른쪽의 첫 번째 숫자 제거:

update tableName set [Title]=left([Title],(len([Title])-1)) where Title like '%村'

False 테이블에서 중복된 중복 레코드(여러 필드) 삭제 , 가장 작은 rowid를 가진 레코드를 포함하지 않습니다

update vitae set ispass=-1where peopleId in (select peopleId from vitae group by peopleId

관련 권장 사항: "mysql tutorial"

위 내용은 SQL에서 중복 데이터를 삭제하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.