MariaDB-중복 관리

이전 단원에서 설명한 것처럼 MariaDB는 일부 상황에서 중복 레코드와 테이블을 허용합니다. 이러한 중복 항목 중 일부는 고유 한 데이터 또는 개체 유형으로 인해 또는 작업 개체의 고유 한 수명 또는 저장으로 인해 실제로 중복되지 않습니다. 이러한 중복은 일반적으로 문제가되지 않습니다.

일부 상황에서 중복은 문제를 일으키며 암시 적 작업이나 MariaDB 명령의 관대 한 정책으로 인해 종종 나타납니다. 이 문제를 제어하고, 중복을 찾고, 중복을 삭제하고, 중복 생성을 방지하는 방법이 있습니다.

전략 및 도구

중복을 관리하는 네 가지 주요 방법이 있습니다.

  • JOIN으로 그들을 찾고 임시 테이블로 삭제하십시오.

  • 중복 발견시 업데이트하려면 INSERT ... ON DUPLICATE KEY UPDATE를 사용하십시오.

  • DISTINCT를 사용하여 SELECT 문의 결과를 정리하고 중복을 제거합니다.

  • 중복 삽입을 중지하려면 INSERT IGNORE를 사용하십시오.

임시 테이블과 결합 사용

내부 조인과 같은 세미 조인을 수행 한 다음 임시 테이블에서 찾은 중복을 제거하기 만하면됩니다.

INSERT 사용

INSERT ... ON DUPLICATE KEY UPDATE가 중복 된 고유 키 또는 기본 키를 발견하면 업데이트를 수행합니다. 여러 개의 고유 키를 발견하면 첫 번째 키만 업데이트합니다. 따라서 여러 고유 인덱스가있는 테이블에서는 사용하지 마십시오.

채워진 필드에 삽입 할 때 인덱싱 된 값을 포함하는 테이블에서 어떤 일이 발생하는지 보여주는 다음 예제를 검토하십시오.

INSERT INTO add_dupl VALUES (1,'Apple');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'

Note − 키를 찾지 못하면 INSERT ... ON DUPLICATE KEY UPDATE 문은 일반 삽입 문처럼 실행됩니다.

DISTINCT 사용

DISTINCT 절은 결과에서 중복을 제거합니다. DISTINCT 절의 일반 구문은 다음과 같습니다.

SELECT DISTINCT fields
FROM table
[WHERE conditions];

Note − DISTINCT 절이있는 명령문의 결과 −

  • 하나의 표현식을 사용하면 고유 한 값을 반환합니다.

  • 여러 표현식을 사용하는 경우 고유 한 조합을 반환합니다.

  • NULL 값을 무시하지 않습니다. 따라서 결과에는 고유 값으로 NULL도 포함됩니다.

단일 표현식에 대해 DISTINCT 절을 사용하여 다음 문을 검토하십시오.

SELECT DISTINCT product_id
FROM products
WHERE product_name = 'DustBlaster 5000';

여러 표현식을 사용하여 다음 예제를 검토하십시오.

SELECT DISTINCT product_name, product_id
FROM products
WHERE product_id < 30

INSERT IGNORE 사용

INSERT IGNORE 문은 중복 레코드 발견시 삽입을 취소하도록 MariaDB에 지시합니다. 아래에 주어진 사용 예를 검토하십시오.

mysql> INSERT IGNORE INTO customer_tbl (LN, FN)
   VALUES( 'Lex', 'Luther');

또한 중복의 논리에 유의하십시오. 일부 테이블은 해당 테이블 데이터의 특성에 따라 중복이 필요합니다. 중복 기록을 관리하기위한 전략에서 이러한 요구를 수용하십시오.