MySQL에서 중복 행을 삽입하지 않으려면 UNIQUE()를 사용할 수 있습니다. 구문은 다음과 같습니다 -
ALTER TABLE yourTableName ADD UNIQUE(yourColumnName1,yourColumnName2,...N);
위의 구문을 이해하기 위해 테이블을 생성해 보겠습니다.
테이블을 생성하는 쿼리는 다음과 같습니다 -
mysql> create table avoidInsertingDuplicateRows -> ( -> Id int NOT NULL AUTO_INCREMENT PRIMARY KEY, -> FirstValue int, -> SecondValue int -> ); Query OK, 0 rows affected (0.53 sec)
이제 desc 명령을 사용하여 테이블의 설명을 확인하십시오.
쿼리는 다음과 같습니다 -
mysql> desc avoidInsertingDuplicateRows;
샘플 다음은 출력입니다 -
+-------------+---------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------------+---------+------+-----+---------+----------------+ | Id | int(11) | NO | PRI | NULL | auto_increment | | FirstValue | int(11) | YES | | NULL | | | SecondValue | int(11) | YES | | NULL | | +-------------+---------+------+-----+---------+----------------+ 3 rows in set (0.00 sec)
다음은 MySQL에 중복 행을 삽입하지 않는 쿼리입니다. 테이블에 레코드를 삽입하기 위해 insert 명령으로 설정합니다 -
mysql> insert into avoidInsertingDuplicateRows(FirstValue,SecondValue) values(10,20); Query OK, 1 row affected (0.24 sec) mysql> insert into avoidInsertingDuplicateRows(FirstValue,SecondValue) values(10,20); ERROR 1062 (23000): Duplicate entry '10-20' for key 'FirstValue'
select 문을 사용하여 테이블의 모든 레코드를 표시합니다.
쿼리는 다음과 같습니다 -
mysql> select *from avoidInsertingDuplicateRows;
다음은 출력입니다 -
+----+------------+-------------+ | Id | FirstValue | SecondValue | +----+------------+-------------+ | 1 | 10 | 20 | +----+------------+-------------+ 1 row in set (0.00 sec)