Mysql的两种覆盖表中重复记录的方法

replace into 方式

前提条件

表中必须有主键或者唯一索引。

原理

根据主键或唯一索引找到相同主键的数据,然后删除原先的数据,再添加新的数据。

如果表中没有相同的主键或唯一索引,则相当于insert into。

使用案例

# topic、partition、groupid是主键
replace into t_offset (`topic`, `partition`, `groupid`, `offset`) values(?,?,?,?)")

ON DUPLICATE KEY UPDATE 方式

前提条件

表中必须有主键或者唯一索引。

原理

根据主键或唯一索引找到相同主键的数据,然后执行update更新操作。

如果表中没有相同的主键或唯一索引,则相当于insert into。

使用案例

# userid是主键
insert into black_list(userid) value (?)
on DUPLICATE KEY
UPDATE userid = ?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值