mysql insert 避免重复方法大全,所有你想知道的

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;

完了,该写的都写了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值