Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > MySQL中insertOrUpdate功能

MySQL中insertOrUpdate的功能实现方式

作者:_派大星

文章介绍了MySQL中实现`insertOrUpdate`功能的`INSERT INTO...ON DUPLICATE KEY UPDATE`语句,并探讨了其工作原理、执行流程以及潜在的死锁问题,同时,还提到了类似SQL语句如`REPLACE INTO`和`INSERT IGNORE INTO`的区别,并讨论了主键跳跃的现象

insertOrUpdate在我们日常使用中比较常见,那么它是如何实现的呢,不知道大家有没有考虑过呢?

在MySQL中,可采用INSERT INTO ... ON DUPLICATE KEY UPDATE语句实现insertOrUpdate功能。

值得留意的是,在出现重复键时,会在先前索引值和当前值之间添加临时键锁,这可能导致死锁。

若要使用INSERT INTO … ON DUPLICATE KEY UPDATE语句,需满足以下条件:

举个例子:

设想有一张student表,包括id、name和age三列,其中id是主键。现在要插入一条数据,若该数据的主键已存在,则更新该数据的姓名和年龄,否则插入该数据。

INSERT INTO student (id, name, age) VALUES (1, 'Paidaxing', 20)
ON DUPLICATE KEY UPDATE name='Paidaxing', age=18;

底层实现

使用INSERT INTO ... ON DUPLICATE KEY UPDATE语句,如果数据库中已存在具有相同唯一索引或主键的记录,则更新该记录。

其底层原理和执行流程如下:

相似SQL

除了INSERT INTO … ON DUPLICATE KEY UPDATE之外,还有一些类似的SQL语句,比如:

浅谈主键跳跃

在MySQL中使用INSERT ON DUPLICATE KEY UPDATE语句时,如果插入操作失败(因为主键或唯一键冲突),而执行了更新操作,确实会导致自增主键计数器增加,即使没有实际插入新记录。

这是因为MySQL在尝试插入新记录时,会先分配一个新的自增主键值,无论后续是插入成功还是执行更新操作,这个主键值都已经被分配并且会增加。

例如,假设有一个表test定义如下:

CREATE TABLE test (
    id INT AUTO_INCREMENT PRIMARY KEY,
    value VARCHAR(255),
    UNIQUE KEY unique_value (value)
);

然后执行以下语句:

INSERT INTO test (value) VALUES ('a') 
ON DUPLICATE KEY UPDATE value = 'a';

再执行一次:

此时,由于value列存在唯一键约束,并且已经存在一条记录value=‘a’,所以不会插入新记录,而是会执行更新操作。但即便如此,自增主键id的计数器依然会增加。

然后再插入一条新的记录:

这意味着下一次插入新记录时,自增主键的值会比之前增加,即2已经被用过了,虽然没插入成功,但是新的记录就直接用3了。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文