当前位置: 首页 > article >正文

【mysql】有索引和没有索引字段更新时锁的不同

结论

    对于有索引的的字段作为更新条件,如果更加语句用上了索引,那么只会在对于的更新字段的索引和对于记录的主键索引上加上x锁

    如果更新字段没有索引,由于需要全部扫描,那么就会给所有主键索引加上x,导致其他事务的更新操作被阻塞

准备

有表 t_person_info,create_time没有加索引,有记录: 4429

执行无索引字段更新

执行下面的事务,不提交


begin;
update  t_person_info set type='2' where create_time>SYSDATE()-2 and create_time<=SYSDATE()-1;

rollback;

查看锁信息(mysql8版本)

 

执行有索引记录更新

   给create_time创建索引。

ALTER TABLE `datacatlog`.`t_person_info` 
ADD INDEX `idx_create_time`(`create_time`) USING BTREE;

sql: 

select  * from t_person_info where create_time<STR_TO_DATE('05/10/2024 14:30:00', '%d/%m/%Y %H:%i:%s')
   and create_time>STR_TO_DATE('05/10/2022 14:30:00', '%d/%m/%Y %H:%i:%s')

 执行计划:


EXPLAIN select  * from t_person_info where create_time<STR_TO_DATE('05/10/2024 14:30:00', '%d/%m/%Y %H:%i:%s')
   and create_time>STR_TO_DATE('05/10/2022 14:30:00', '%d/%m/%Y %H:%i:%s')

  

然后再更新:


begin;
update  t_person_info set type='2' where create_time>SYSDATE()-2 and create_time<=SYSDATE()-1;

rollback;

 查看锁信息(mysql8版本)

可以看到上面查询的符合条件的记录都被加上x锁了。

然后执行其他更新操作:

 

执行无主键和无唯一键的表更新 

    t_test表有test1 test2 test3三个字段,但是没有任何索引,也没有主键

  

 

 开始一个执行更新事务

BEGIN;

update t_test set test1='r2rr' where test2='233';


ROLLBACK

 


http://www.kler.cn/a/570848.html

相关文章:

  • C# OnnxRuntime部署DAMO-YOLO香烟检测
  • Spring Boot 自动装配深度解析与实践指南
  • React 源码揭秘 | bailout策略Memo
  • 力扣每日一题——分割回文串
  • Skyeye 云智能制造办公系统 VUE 版本 v3.15.11 发布
  • 迷你世界脚本实体接口:Actor
  • Unity 接入本地部署的DeepSeek
  • pytest的bug
  • (十 九)趣学设计模式 之 中介者模式!
  • Leetcode 54: 螺旋矩阵
  • 大白话实战docker
  • 计算机基础面试(数据库)
  • 基于springboot+vue3图书借阅管理系统
  • Linux网络相关概念和重要知识(1)(网络协议、网络通信)
  • SEKI —— 基于大型语言模型的自进化与知识启发式神经架构搜索
  • SSM家谱管理系统
  • 蓝桥杯备考:动态规划入门题目之下楼梯问题
  • 华硕电脑开启电池保养模式的方法
  • 用Python+Flask打造可视化武侠人物关系图生成器:从零到一的实战全记录
  • Linux 下使用vmstat监控系统性能