Commande | existe déjà | n'existe pas | Exemple |
---|---|---|---|
insérer | rapport d'erreurs | insérer | insérer dans les noms (nom, age) valeurs ("小明", 23); |
insérer ignorer | ignorer | insérer ignorer dans les noms (nom, âge) valeurs ("小明", 24); Insérez | remplacer dans les noms (nom, âge) valeurs ("Xiao Ming", 25); |
Exigences de la table : clé primaire ou index unique | Résultat : l'identifiant de la table sera incrémenté | Code de test | Table de création |
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 | +----+--------+------+
insérer
L'insertion existe déjà, l'identifiant sera incrémenté, mais si l'insertion échoue, une erreur sera signalée
mysql> insert into names(name, age) values("小明", 23); ERROR 1062 (23000): Duplicate entry '小明' for key 'name'
Le remplacement existe déjà, supprimez l'enregistrement d'origine , et ajoutez un nouvel enregistrement
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 | +----+--------+------+
Il n'y a pas de remplacement, ajoutez un nouvel enregistrement
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 | +----+--------+------+
L'insertion existe déjà, ignorez l'enregistrement nouvellement inséré, l'identifiant augmentera automatiquement, aucune erreur ne sera signalée
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 | +----+--------+------+
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!