insert 的所有困惑都在这。
若要避免向 MySQL 数据库插入重复记录,您可以使用 INSERT IGNORE 语句或 REPLACE 语句。
INSERT IGNORE
REPLACE
以下是使用 INSERT IGNORE 语句的示例:
INSERT IGNORE
INSERT IGNORE INTO 表名 (列 1,列 2, ...)
VALUES (值 1,值 2, ...);
如果没有具有相同唯一键的行,则 INSERT IGNORE 语句将插入新行。如果具有相同唯一键的行已存在,则 INSERT IGNORE 语句将忽略新行并不插入它。
INSERT IGNORE
INSERT IGNORE
以下是使用 REPLACE 语句的示例:
REPLACE
REPLACE INTO 表名 (列 1,列 2, ...)
VALUES (值 1,值 2, ...);
如果没有具有相同唯一键的行,则 REPLACE 语句将插入新行。如果具有相同唯一键的行已存在,则 REPLACE 语句将删除旧行并插入新行。
REPLACE
REPLACE
请注意,与普通 INSERT 语句相比,INSERT IGNORE 和 REPLACE 语句可能会慢一些,因为它们在插入或替换行之前需要执行额外的检查。
```sql
INSERT
INSERT IGNORE
REPLACE
另一种避免插入重复记录的方法是使用 INSERT 语句的 ON DUPLICATE KEY UPDATE 子句。这允许您指定遇到重复键时应采取的操作。
```sql
INSERT
ON DUPLICATE KEY UPDATE
以下是使用 ON DUPLICATE KEY UPDATE 子句的示例:
ON DUPLICATE KEY UPDATE
INSERT INTO 表名 (列 1,列 2, ...)
VALUES (值 1,值 2, ...)
ON DUPLICATE KEY UPDATE 列 1 = 值 1,列 2 = 值 2, ...;
在这个例子中,如果具有相同唯一键的行已经存在,则 INSERT
语句将使用 ON DUPLICATE KEY UPDATE
子句中指定的新值更新现有行。
您还可以使用 ON DUPLICATE KEY IGNORE
子句指定遇到重复键时不执行任何操作。
INSERT INTO 表名 (列 1,列 2, ...)
VALUES (值 1,值 2, ...)
ON DUPLICATE KEY IGNORE;
完了,该写的都写了