제가 가지고 있는 자료를 만지며 연습하다가 궁금증이 생겼는데요, 예를 들어 주민번호가 있는 테이블이라고 할께요.
A테이블에 주민번호가 중복되는 자료가 마구 섞여 있습니다. 여기서 중복되는 자료를 지우지 않고 사사삭 뽑아내어 B라는 테이블를 만들고 싶은데 어떻게 하는지 궁금합니다.
테이블 이름이 test_tbl 이고 주민등록번호 컬럼이 scn 이라고 할 때, 아래와 같이 하시면 주민등록번호가 같은 레코드들중 가장 먼저 입력된 레코드 하나만 제외하고 나머지 중복 레코드를 골라내어 새로운 테이블인 dup_tbl에 넣어줄 것입니다. 원본테이블은 그대로 보존됩니다.
CREATETABLE dup_tbl ASSELECT*FROM test_tbl a
WHERE rowid !=(SELECTMIN(rowid)FROM test_tbl b WHERE b.scn = a.scn);
동작원리는 간단합니다. SQLite의 테이블에는 rowid라는 숨은 컬럼이 하나씩 있는데, 간단히 테스트해보니 테이블에 레코드가 insert 될 때마다 1씩 증가하는 정수값이더군요. 따라서 이 값이 가장 작은 레코드가 가장 먼저 insert된 레코드인 셈입니다. 만약 중복 레코드중 가장 먼저 insert된 것 말고 가장 늦게 insert된 것을 제외시키고 싶다면 MIN()을 MAX()로 바꾸면 되겠죠.
위의 SQL문을 좀 변형하면 다른 용도로 쓸 수도 있는데요. 아래와 같이 CREATE TABLE 부분을 제거하면, 새 테이블을 만들지 말고 중복데이터 열람만 할 수 있습니다.
SELECT*FROM test_tbl a
WHERE rowid !=(SELECTMIN(rowid)FROM test_tbl b WHERE b.scn = a.scn);
만약 원본테이블에서 중복레코드를 제거하고 싶다면 SELECT를 DELETE문으로 바꾸면 되고요.
DELETEFROM test_tbl a
WHERE rowid !=(SELECTMIN(rowid)FROM test_tbl b WHERE b.scn = a.scn);
테이블 이름이 test_tbl 이고 주민등록번호
테이블 이름이 test_tbl 이고 주민등록번호 컬럼이 scn 이라고 할 때, 아래와 같이 하시면 주민등록번호가 같은 레코드들중 가장 먼저 입력된 레코드 하나만 제외하고 나머지 중복 레코드를 골라내어 새로운 테이블인 dup_tbl에 넣어줄 것입니다. 원본테이블은 그대로 보존됩니다.
동작원리는 간단합니다. SQLite의 테이블에는 rowid라는 숨은 컬럼이 하나씩 있는데, 간단히 테스트해보니 테이블에 레코드가 insert 될 때마다 1씩 증가하는 정수값이더군요. 따라서 이 값이 가장 작은 레코드가 가장 먼저 insert된 레코드인 셈입니다. 만약 중복 레코드중 가장 먼저 insert된 것 말고 가장 늦게 insert된 것을 제외시키고 싶다면 MIN()을 MAX()로 바꾸면 되겠죠.
위의 SQL문을 좀 변형하면 다른 용도로 쓸 수도 있는데요. 아래와 같이 CREATE TABLE 부분을 제거하면, 새 테이블을 만들지 말고 중복데이터 열람만 할 수 있습니다.
만약 원본테이블에서 중복레코드를 제거하고 싶다면 SELECT를 DELETE문으로 바꾸면 되고요.
오... 감사합니다. 오늘 오후에 꼭 해보고
오... 감사합니다.
오늘 오후에 꼭 해보고 말씀드릴께요. ^^b
------------------------------------------------------------------------
컴퓨터를 좋아하는 일반인이에요..
행복하고 싶어요
댓글 달기