MySQL 四种插入命令及其特点与锁机制

目录

[1. INSERT INTO](#1. INSERT INTO)

[2. INSERT IGNORE INTO](#2. INSERT IGNORE INTO)

[3. INSERT INTO ... ON DUPLICATE KEY UPDATE](#3. INSERT INTO ... ON DUPLICATE KEY UPDATE)

[4. REPLACE INTO](#4. REPLACE INTO)

总结


MySQL提供了多种数据插入方式,每种方式在处理唯一键冲突时的行为不同,同时也涉及不同的锁机制。

1. INSERT INTO

INSERT INTO是标准的数据插入命令,用于在表中插入新行。

特点: 无就插入、有就报错

  • 插入新行。
  • 如果新行违反唯一键约束,则会产生错误并中止插入。

:

  • 通常获取行锁,锁定被插入的行。
  • 如果使用了事务隔离级别(可重读),可能还会涉及间隙锁,以防止幻读。
  • 正常情况下,如果按照唯一键顺序插入,死锁风险较低。

2. INSERT IGNORE INTO

INSERT IGNORE INTO在插入时忽视唯一键约束冲突。

特点: 无就插入,有就忽略当前行

  • 插入新行,但如果违反唯一键约束则忽略错误。
  • 不会因为唯一键冲突而中止操作。

:

  • 类似INSERT INTO,获取行锁。
  • 由于忽略冲突,可能减少锁竞争,降低死锁风险。

3. INSERT INTO ... ON DUPLICATE KEY UPDATE

在唯一键冲突时,更新现有的冲突行。

特点: 无就插入,有就更新

  • 如果没有唯一键冲突则插入,否则更新冲突行。
  • 避免了插入错误,提供了一种"尝试插入否则更新"的机制。

:

  • 获取行锁来插入或更新数据。
  • 如果涉及更新,可能会获取间隙锁,尤其在高并发环境下。
  • 更新操作增加了死锁的潜在风险。

4. REPLACE INTO

如果存在唯一键冲突,则删除旧行后插入新行。

特点: 无就插入,有就先删后插,

  • 插入前,先检查唯一键冲突,有则删除冲突行。
  • 实质上是一个删除再插入的操作。

:

  • 获取行锁以删除和插入数据。
  • 可能会获取间隙锁,尤其是在删除旧行时。
  • 由于涉及删除操作,可能会触发更复杂的锁机制,增加死锁风险。

总结

不同的插入命令在处理唯一键冲突时具有不同的行为。在锁的层面,INSERT INTOINSERT IGNORE INTO通常涉及行锁,而INSERT INTO ... ON DUPLICATE KEY UPDATEREPLACE INTO可能会涉及间隙锁,特别是在并发环境下。间隙锁是为了保持事务隔离性而设置的,它锁定了一个范围,防止其他事务插入到这个范围内。每种方式在并发场景下都有可能产生死锁,尤其是在多个事务试图以不同顺序访问同一组数据时。因此,设计数据库操作时需要考虑锁的影响,合理安排事务顺序,以减少死锁的可能性。

相关推荐
少云清7 分钟前
【性能测试】3_性能测试基础 _指标
运维·服务器·数据库·性能测试·性能测试指标
+VX:Fegn08958 分钟前
计算机毕业设计|基于springboot + vue物流配送中心信息化管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·小程序·课程设计
计算机毕设指导620 分钟前
基于微信小程序的钓鱼论坛系统【源码文末联系】
java·spring boot·mysql·微信小程序·小程序·tomcat·maven
列御寇34 分钟前
MongoDB分片集群——集群组件概述
数据库·mongodb
七夜zippoe40 分钟前
领域驱动设计在Python中的实现:从理论到生产级实践
数据库·python·sqlite·ddd·pydantic
小CC吃豆子41 分钟前
Qt的信号与槽机制
开发语言·数据库·qt
·云扬·44 分钟前
系统与MySQL核心监控指标及操作指南
android·数据库·mysql
七夜zippoe1 小时前
数据库事务隔离级别与Spring传播行为深度解析
java·数据库·spring·mvcc·acid·myslq
VX:Fegn08951 小时前
计算机毕业设计|基于springboot + vue智慧养老院管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
霖霖总总1 小时前
[小技巧15]深入解读 MySQL sql_mode:从原理到实践,规避常见坑
sql·mysql