深度剖析onduplicate

在MySQL中,onduplicate被广泛使用来处理对于重复的主键或唯一索引值。具体来说,它通过一条INSERT语句,当有重复的主键或唯一的索引出现时,会执行下一步操作。常见的有覆盖(insert into… onduplicate key do nothing),更新(insert into… onduplicate key update )等操作

一、onduplicate key do not

当主键或唯一索引重复时,INSERT语句将不会进行任何操作,并忽略这一行的插入

insert into table_name (primary_key, column1, column2, ...) values (value1, value2, value3, ...) 
onduplicate key do nothing

实现上,ONDUP_HANDLERR_FUNC 类型的函数do_nothing_handler()以及do_nothing()函数会被调用, 在do_nothing_handler()函数中什么都没有做,因此会直接跳出函数。

二、onduplicate key update where

当主键或唯一索引重复时,MySQL实现了相关的Updating机制。以onduplicate key update where这条语句为例, 当插入的主键重复时,会根据where分句指定的条件来更新。举个例子,假设存在主键为id的一条记录,需要更新column1的值。可以用以下代码完成:

insert into table_name (primary_key, column1, column2, ...) 
values (value1, value2, value3, ...) 
onduplicate key update set column1=new_value where id=primary_key_value

在执行这个语句的时候,MySQL会先检查表中是否已经有了值为primary_key_value的行。如果有的话,MySQL会更新对应行的column1的值为new_value。如果没有,MySQL会插入一行:

insert into table_name (primary_key, column1, column2, ...)
values (value1, value2, value3, ...)

这个特性可以非常方便地插入带有唯一性约束的数据,并防止出现冲突。

三、onduplicate key

在执行 INSERT INTO … ON DUPLICATE KEY UPDATE 时,MySQL会在插入过程中根据PRIMARY KEY 或 UNIQUE KEY 约束,检查新插入的行是否与表中已有的行有重复之处,如果有,则执行UPDATE操作。如果没有,则执行INSERT操作。

insert into table_name (primary_key, column1, column2, ...) 
values (value1, value2, value3, ...) 
onduplicate key 
column1 = case when values(column1) is null then column1 else values(column1) end, 
column2 = case when values(column2) is null then column2 else values(column2) end

当主键或唯一索引重复时,UPDATE语句的作用是将主键ID为X的行更新为值为Y的行, 如果不存在这样的行, INSERT语句插入一条新记录。

四、onduplicate key update性能

在执行INSERT INTO … ON DUPLICATE KEY UPDATE 的时候,不论数据是插入还是更新,MySQL都会把行锁定在内存中,直到整个命令完成后释放。如果并发插入过多会增加锁超时的风险。因此,在实际需求中需要进行测试。

五、onduplicate key update锁表

在MySQL 8.0中,当“INSERT ON DUPLICATE KEY UPDATE”查询在表的行存在重复关键字时进行插入和更新并发访问时存在潜在的锁竞争,因为此时MySQL会有行级锁以及语句级锁的问题。建议在高并发情况下做好数据优化、分片、读写分离等处理。

六、onduplicatekeyupdate批量更新

在有些情况下,我们可能会遇到这样的问题,需要INSERT一组数据,但如果在数据库中已经存在了相同主键的记录,则需要对这些记录进行更新操作。此时,比较高效的方法是使用INSERT INTO … ON DUPLICATE KEY UPDATE语句配合VALUES子句,来实现批量更新。具体来说:

INSERT INTO table_name (primary_key, col1, col2, ...)
VALUES
    (1, 'foo', 'bar'),
    (2, 'baz', 'qux')
ON DUPLICATE KEY UPDATE
    col1=VALUES(col1),
    col2=VALUES(col2);

在这个例子中,如果(1,‘foo’,’bar’)这个主键已经在表中存在,则执行UPDATE操作来更新对应的值。同理,如果表中存在主键为2的记录,则把(2,“baz”、“qux”)这条记录更新到表中。如果表中原来没有这两个主键的记录,则直接执行INSERT操作。

总结

对于大多数数据库管理系统而言,onduplicate是一项非常重要的性能特性。在MySQL中,这个语法早已经成为了开发者们必须要熟练掌握的知识之一。在实际开发过程中,我们可以根据具体情况来选择合适的onduplicate处理方式,并且需要注意性能优化、锁表等问题,以避免在高并发情况下造成数据不一致等问题。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/306669.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2025-01-02 12:01
下一篇 2025-01-02 18:03

相关推荐

  • 深度查询宴会的文化起源

    深度查询宴会,是指通过对一种文化或主题的深度挖掘和探究,为参与者提供一次全方位的、深度体验式的文化品尝和交流活动。本文将从多个方面探讨深度查询宴会的文化起源。 一、宴会文化的起源 …

    编程 2025-04-29
  • Python下载深度解析

    Python作为一种强大的编程语言,在各种应用场景中都得到了广泛的应用。Python的安装和下载是使用Python的第一步,对这个过程的深入了解和掌握能够为使用Python提供更加…

    编程 2025-04-28
  • Python递归深度用法介绍

    Python中的递归函数是一个函数调用自身的过程。在进行递归调用时,程序需要为每个函数调用开辟一定的内存空间,这就是递归深度的概念。本文将从多个方面对Python递归深度进行详细阐…

    编程 2025-04-27
  • Spring Boot本地类和Jar包类加载顺序深度剖析

    本文将从多个方面对Spring Boot本地类和Jar包类加载顺序做详细的阐述,并给出相应的代码示例。 一、类加载机制概述 在介绍Spring Boot本地类和Jar包类加载顺序之…

    编程 2025-04-27
  • 深度解析Unity InjectFix

    Unity InjectFix是一个非常强大的工具,可以用于在Unity中修复各种类型的程序中的问题。 一、安装和使用Unity InjectFix 您可以通过Unity Asse…

    编程 2025-04-27
  • 深度剖析:cmd pip不是内部或外部命令

    一、问题背景 使用Python开发时,我们经常需要使用pip安装第三方库来实现项目需求。然而,在执行pip install命令时,有时会遇到“pip不是内部或外部命令”的错误提示,…

    编程 2025-04-25
  • 动手学深度学习 PyTorch

    一、基本介绍 深度学习是对人工神经网络的发展与应用。在人工神经网络中,神经元通过接受输入来生成输出。深度学习通常使用很多层神经元来构建模型,这样可以处理更加复杂的问题。PyTorc…

    编程 2025-04-25
  • 深度解析Ant Design中Table组件的使用

    一、Antd表格兼容 Antd是一个基于React的UI框架,Table组件是其重要的组成部分之一。该组件可在各种浏览器和设备上进行良好的兼容。同时,它还提供了多个版本的Antd框…

    编程 2025-04-25
  • 深度解析MySQL查看当前时间的用法

    MySQL是目前最流行的关系型数据库管理系统之一,其提供了多种方法用于查看当前时间。在本篇文章中,我们将从多个方面来介绍MySQL查看当前时间的用法。 一、当前时间的获取方法 My…

    编程 2025-04-24
  • 深度学习鱼书的多个方面详解

    一、基础知识介绍 深度学习鱼书是一本系统性的介绍深度学习的图书,主要介绍深度学习的基础知识和数学原理,并且通过相关的应用案例来帮助读者理解深度学习的应用场景和方法。在了解深度学习之…

    编程 2025-04-24

发表回复

登录后才能评论