问题描述:
当使用ON DUPLICATE KEY UPDATE的sql来访问时,
可能会出现多个线程同时写入一个已有的数据里。
解决办法:使用 REPLACE INTO
原因:
- 保持更好的并发性:REPLACE INTO 在插入记录时会先删除原有记录,然后再插入新记录。因此,在多个线程同时执行插入操作时,不会对同一行数据进行更新,从而避免了锁表和并发冲突的问题;
- 简化逻辑:您不需要关心冲突时是更新还是插入新记录的问题,只需要执行插入操作;
举例 :
sqlupdate_sql = "UPDATE 表名 SET 列名1 = %s WHERE 列名2 = %s"更改为:
sqlupdate_sql = "REPLACE INTO 表名 (列名1, 列名2) VALUES (%s, %s)"
多线程使用处理数据库导致锁表解决办法
EaSoNgo1112023-10-14 14:24
相关推荐
大黄说说1 分钟前
MySQL 查询优化三剑客:JOIN、子查询、UNION 的选型策略与性能调优实战砚边数影8 分钟前
架构演进:从单一NoSQL到“一库多模”的融合实践清风~徐~来15 分钟前
【视频点播系统】Redis-SDK 介绍及使用SelectDB技术团队21 分钟前
日志成本降低 83%:云上 Elasticsearch 和 SelectDB 的基准测试及成本分析全栈前端老曹27 分钟前
【Redis】Redis 客户端连接与编程实践——Python/Java/Node.js 连接 Redis、实现计数器、缓存接口霖霖总总28 分钟前
[小技巧72]AFTER COMMIT vs AFTER SYNC:MySQL 半同步复制的持久性博弈麦聪聊数据29 分钟前
后端研发范式演进:从对象映射(ORM)到逻辑解耦(SQL2API)爱敲代码的小鱼34 分钟前
后端web开发Mysql数据库:Franciz小测测35 分钟前
GitLab 双物理机高可用新方案(基于 Rsyncd + Keepalived+PostgreSQL 流复制)野犬寒鸦38 分钟前
WebSocket协同编辑:高性能Disruptor架构揭秘及项目中的实战应用