> 데이터 베이스 > MySQL 튜토리얼 > mysql에서 삽입 무시, 삽입 및 교체의 차이점은 무엇입니까

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

PHPz
풀어 주다: 2023-05-29 16:40:06
앞으로
1662명이 탐색했습니다.

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으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿