일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- patch
- Network
- Oracle RAC
- 오라클
- PERL
- perl + 정규표현식
- dba
- SQL
- mariaDB
- fdisk
- Linux
- rac
- sqlplus
- oracle install
- solaris network
- 연산자
- grid
- solaris
- Unix
- cygwin
- command & perl
- RHEL4
- memory
- prompt
- oracle
- php5
- perl one-liner
- MySQL
- perl string
- bash
Archives
- Today
- Total
DATA 전문가로 가는 길
[SQL] MariaDB/MySQL 테이블 일련번호 중간에 빈 값 찾기 본문
테이블에 존재하는 순서 번호 값 중에서 빈 값을 찾는 쿼리를 작성하겠습니다.
순차적으로 번호가 1번부터 20번까지 존재한다고 했을 때 5번, 11번 ~ 14번, 17번 ~ 18번 이렇게 빈 값이 존재할 경우 찾아내는 방법과 빈 값에 대한 범위를 찾는 방법 그리고 마지막으로 어느 정도 비어있는지 확인 가능합니다.
1. 샘플 데이터
- 샘플 데이터를 생성하고, 임시 데이터를 삽입합니다.
DROP TABLE EST_SEQUENCE; CREATE TABLE EST_SEQUENCE (ID INT NOT NULL PRIMARY KEY) ENGINE=INNODB; INSERT INTO EST_SEQUENCE(ID) SELECT 1 UNION ALL SELECT 2 UNION ALL SELECT 3 UNION ALL SELECT 4 UNION ALL SELECT 6 UNION ALL SELECT 7 UNION ALL SELECT 8 UNION ALL SELECT 9 UNION ALL SELECT 10 UNION ALL SELECT 15 UNION ALL SELECT 16 UNION ALL SELECT 19 UNION ALL SELECT 20 ;
2. 순차적 번호 중에서 빈 값 찾기
- 아래 쿼리 중에서 seq_1_to_10000을 이용해서 로우 데이터를 생성하고, 실제 검수해야 될 테이블을 LEFT OUTER JOIN을 해서 확인합니다.
- 실제 테이블 데이터 중에서 가장 큰 값을 비교해서 적용하면 성능적으로 개선됩니다.
- "r_total_time_ms": 0.1657, => 서브 쿼리 사용 할 때
- "r_total_time_ms": 1.3515, => 서브쿼리 사용 안 할 때
SELECT A.SEQ FROM seq_1_to_10000 A LEFT OUTER JOIN EST_SEQUENCE B ON (B.ID = A.SEQ) WHERE B.ID IS NULL AND A.SEQ <= (SELECT MAX(SQ1.ID) FROM EST_SEQUENCE SQ1 ) ;
[결과]
|SEQ |
|--------------------|
|5 |
|11 |
|12 |
|13 |
|14 |
|17 |
|18 |
3. 순차적 번호 중에서 빈 값에 대한 사이 값 찾기
SELECT CONCAT(X.EXPECTED, IF(X.GOT-1>X.EXPECTED, CONCAT(' ~ ',X.GOT-1), '')) AS MISSING FROM ( SELECT @ROWNUM:=@ROWNUM+1 AS EXPECTED, IF(@ROWNUM=B.ID, 0, @ROWNUM:=B.ID) AS GOT FROM (SELECT @ROWNUM:=0) AS A INNER JOIN EST_SEQUENCE B ORDER BY B.ID ) AS X WHERE X.GOT!=0;
[결과]
|MISSING |
|---------------------------------------------------------------------------------------------|
|5 |
|11 ~ 14 |
|17 ~ 18 |
4. 순차적 번호 중에서 빈 값에 대한 수 구하기
SELECT X.CURRENT_ID AS ID ,X.MIN_ID AS NEXT_ID ,(X.MIN_ID - X.CURRENT_ID) -1 AS MISSING_INBETWEEN FROM ( SELECT A1.ID AS CURRENT_ID , MIN(A2.ID) AS MIN_ID FROM EST_SEQUENCE AS A1 LEFT OUTER JOIN EST_SEQUENCE AS A2 ON A2.ID > A1.ID WHERE A1.ID <= 100 GROUP BY A1.ID ) AS X WHERE X.MIN_ID > X.CURRENT_ID + 1 ;
[결과]
|ID |NEXT_ID |MISSING_INBETWEEN|
|-----------|-----------|-----------------|
|4 |6 |1 |
|10 |15 |4 |
|16 |19 |2 |
'Data Architecture > SQL Query' 카테고리의 다른 글
[SQL] MariaDB/MySQL 테이블 비교(Compare two table) (0) | 2019.07.29 |
---|---|
[SQL] Oracle Merge 문법 자동 생성기(PL/SQL) (0) | 2017.09.25 |
[SQL] MariaDB/MySQL MAX/MIN 최고값 최저값의 세부 속성 데이터 활용하기(최고일시, 최저일시 등) (0) | 2017.03.24 |
[SQL] Oracle 필수 스크립트 모음(딕셔너리, SQL 문법, 성능 분석) (0) | 2017.03.13 |
[SQL] MariaDB/Mysql 구분자(콤마, 파이프라인 등등)를 기준으로 열(row) 변환 (2) | 2017.02.16 |
Comments