1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다."/> 1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다.">
집 >데이터 베이스 >MySQL 튜토리얼 >SQL에서 중복 데이터를 삭제하는 방법
SQL에서는 select 문을 사용하여 중복 데이터를 삭제할 수 있습니다. 구문은 "필드 ID가 있는 필드에서 * 선택(개수(필드 ID) > 1인 필드별로 필드 그룹에서 필드 ID 선택)"입니다.
이 튜토리얼의 운영 환경: 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!