>  기사  >  데이터 베이스  >  mysql에서 삽입 무시, 삽입 및 교체의 차이점은 무엇입니까

mysql에서 삽입 무시, 삽입 및 교체의 차이점은 무엇입니까

PHPz
PHPz앞으로
2023-05-29 16:40:061513검색

insert 무시, 삽입 및 바꾸기의 차이점

replace테이블 요구 사항: PrimaryKey 또는 고유 인덱스
Command 이 이미 존재합니다 존재하지 않습니다 Example
insert 오류 보고 insert 이름에 삽입(이름, age) 값("작은명", 23);
insert 무시 ignore insert 무시 이름(이름, 나이) 값("작은명", 24);
replace 이름(이름, 나이) 값("Xiao Ming", 25)에 replace를 삽입합니다.

결과: 테이블 ID가 증가합니다

테스트 코드

생성 테이블

CREATE TABLE names(
    id INT(10) PRIMARY KEY AUTO_INCREMENT,
    name VARCHAR(255) UNIQUE,
    age INT(10)
)

데이터 삽입

mysql> insert into names(name, age) values("小明", 24);
mysql> insert into names(name, age) values("大红", 24);
mysql> insert into names(name, age) values("大壮", 24);
mysql> insert into names(name, age) values("秀英", 24);

mysql> select * from names;
+----+--------+------+
| id | name   | age  |
+----+--------+------+
|  1 | 小明   |   24 |
|  2 | 大红   |   24 |
|  3 | 大壮   |   24 |
|  4 | 秀英   |   24 |
+----+--------+------+

insert

삽입이 이미 존재하므로 ID가 증가하지만 삽입에 실패하면 오류가 보고됩니다.

mysql> insert into names(name, age) values("小明", 23);

ERROR 1062 (23000): Duplicate entry '小明' for key 'name'

replace

교체가 이미 존재하므로 원본 레코드를 삭제하세요. , 그리고 새 레코드를 추가하세요

mysql> replace into names(name, age) values("小明", 23);
Query OK, 2 rows affected (0.00 sec)

mysql> select * from names;
+----+--------+------+
| id | name   | age  |
+----+--------+------+
|  2 | 大红   |   24 |
|  3 | 大壮   |   24 |
|  4 | 秀英   |   24 |
|  6 | 小明   |   23 |
+----+--------+------+

교체가 없습니다. 새 레코드를 추가하세요

mysql> replace into names(name, age) values("大名", 23);
Query OK, 1 row affected (0.00 sec)

mysql> select * from names;
+----+--------+------+
| id | name   | age  |
+----+--------+------+
|  2 | 大红   |   24 |
|  3 | 大壮   |   24 |
|  4 | 秀英   |   24 |
|  6 | 小明   |   23 |
|  7 | 大名   |   23 |
+----+--------+------+

삽입 무시

삽입이 이미 있습니다. 새로 삽입된 레코드를 무시하세요. ID가 증가하며 오류가 보고되지 않습니다

mysql> insert ignore into names(name, age) values("大壮", 25);
Query OK, 0 rows affected, 1 warning (0.00 sec)

삽입된 내용이 없습니다. 새 레코드를 추가하세요

mysql> insert ignore into names(name, age) values("壮壮", 25);
Query OK, 1 row affected (0.01 sec)

mysql> select * from  names;
+----+--------+------+
| id | name   | age  |
+----+--------+------+
|  2 | 大红   |   24 |
|  3 | 大壮   |   24 |
|  4 | 秀英   |   24 |
|  6 | 小明   |   23 |
|  7 | 大名   |   23 |
| 10 | 壮壮   |   25 |
+----+--------+------+

위 내용은 mysql에서 삽입 무시, 삽입 및 교체의 차이점은 무엇입니까의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제