Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL에서 중복 행 삽입을 피하는 방법은 무엇입니까?

<시간/>

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)