首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL Update执行流程解读

一、update跟踪执行配置 使用内部程序堆栈跟踪工具path_viewer,跟踪mysql update 一行数据的执行过程,配置执行脚本:call_update.sh DROP DATABASE...::prepare(THD*) --引用消解 Sql_cmd_update::precheck(THD*) --更新语句实际执行的引用消解 Sql_cmd_update::execute_inner...(THD*) --SQL引擎层,调用存储引擎接口执行 Sql_cmd_update::update_single_table(THD*) optimize_cond --执行优化器优化路径...(THD*, bool) innoDB关键更新执行过程 ha_innobase::update_row: row_get_prebuilt_update_vector calc_row_difference...三、执行总结 update执行流程 1.执行语句连接数据库 2.分析器通过词法、语法分析知道这是一条更新语句 3.优化器确定执行路径 4.执行器具体执行,找到这一行,更新数据,然后通过Inodb存储具体更新操作

2.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    proc 编程执行 insert、delete、update语句

    主题中提到的三种语句都是没有返回值的,所以我们实现起来也最简单,下面代码中包含了 insert、update 和 delete 三种语法的使用。...值得注意的是在 insert 和 update 的时候使用宿主变量时的语法,在宿主变量前一定要加冒号,这是初学者最容易犯的错误。...} printf("update success......\\n"); // 对上面执行的操作执行一次提交 EXEC SQL commit; // 删除 dept 表中 deptno 为 50 的数据 EXEC SQL delete from dept where...表中的原有如下数据: 执行我们的程序(注意,在程序执行前,你要操作的数据必须都是真正提交到数据库中的,如果操作了未commit的数据,那么程序就会卡住不动): 执行后再次查看数据库:

    33320

    MySQL Update语句是怎么执行的?

    MySQL Update语句是怎么执行的?...[isd2tnp037.png] 昨天,我们利用这张图,了解了一个select语句的执行过程,讲解了连接器、查询缓存、分析器、优化器、执行器等模块的作用,今天我们来看一条update语句是怎么执行的...其实,update语句的执行过程和select语句差不多,但是在update语句执行的过程中,MySQL新增加了两个重要的日志模块,他们分别是redo log(重做日志)和binlog(二进制日志、也可以称之为归档日志...b、执行器拿到Innodb存储引擎接口给的数据,执行update操作,得到新的数据,然后调用Innodb存储引擎的接口写入数据。...然后告知执行执行完成了,随时可以提交事务。 d、执行器生成update操作的binlog,并把binlog写入磁盘。

    4.5K40

    从 MySQL 执行 update 报错 ERROR 1292 说起

    DBA之路(ID: JiekeXu_IT) 如需转载请联系授权 | (个人微信 ID:JiekeXu_DBA) 大家好,我是 JiekeXu,很高兴又和大家见面了,今天和大家一起来看看 MySQL 执行...事情是这样的,上周五下班前通过自动化工具执行开发人员事先写好的 SQL 时,自动化工具执行失败了,于是手动去生产环境执行,就发生了错误 “ERROR 1292 (22007): Truncated incorrect...PRIMARY KEY (`sequence_no`), UNIQUE KEY `u_t_ar_busi_contract_01` (`id`), ); 然后使用客户端可视化工具、Xshell 命令行执行均出现一样的报错...上面图中“update t set id=‘6’ and c=‘6’ where d=1;”和“update t set id=‘6’ and c=‘1’ where d=1;” 都执行成功了,但是更新成功的值却不一样...在我的 Oracle 23c 的测试环境中,我去模拟了上面的操作,直接执行此 SQL 就报错了,ORA-00920 操作无效。

    58320

    update执行流程(MySQL redo log和binlog详解)

    test set score = 3 where id = 2; update语句也需要经过连接器、分析器、优化器、执行器,但是update语句相比select语句还是有很大不同的,更新流程设计两个重要的日志模块...真正的将日志写入到redo log文件(ib_logfile+数字)是在执行commit语句的时候执行。...UPDATE语句的执行流程 update test set score = 3 where id = 2; 整个update语句中牵涉到写redo log和binlog,并且redo log在前,binlog...-- score原始值为1 update test set score = 3 where id = 2; 假设我们的update语句在写完redo log,binlog还没写时系统发生了crash。...-- score原始值为1 update test set score = 3 where id = 2; 假设我们的update语句在写完binlog,redo log还没写时系统发生了crash。

    1.8K10

    Vps是什么技术?服务器如何vps

    服务器如何vps?...Vps是什么技术 Vps是主机的一种形式,它能够将服务器进行分解,分为多个虚拟的服务器供企业使用,每一个Vps主机能够分配一个独立的ip地址和相应系统,这个系统拥有较大的储存空间,cpu资源也十分充分,...能够满足企业日常的程序执行,企业使用这个主机后用网安全和办公效率都会得到一定提高,那服务器如何vps?...服务器如何vps Vps主机相当于一台电脑的大脑,可以安装独立程序,但这个虚拟器主机是服务商提供的,服务器如何vps?...想要将服务器设置为vps需要采购虚拟主机,专业的服务商会根据企业需求设计vps,并且24小时有专人观看数据,如果发生异常将第一时间解决,为企业带来优质的运维管理,因此企业在选择Vps服务商时,尽量选择知名服务公司

    28.2K30

    执行update语句,用没用到索引,区别大吗?

    前言: 我们都知道,当执行 select 查询语句时,用没用到索引区别是很大的,若没用到索引,一条 select 语句可能执行好几秒或更久,若使用到索引则可能瞬间完成。...那么当执行 update 语句时,用没用到索引有什么区别呢,执行时间相差大吗?本篇文章我们一起来探究下。...其中 col1 字段区分度较高,del 字段区分度很低,下面我们分别以这两个字段为筛选条件来执行 update 语句: # 以 col1 字段为筛选条件 来更新 col2 字段 mysql> explain...2.一些经验总结 我们试着来解释下以上实验结果,首先来看下 update SQL 执行流程,大致如下: 首先客户端发送请求到服务端,建立连接。...也就是说,执行更新语句首先需要将被更新的记录查询出来,这也就不难理解为啥以区分度较高的字段为筛选条件进行更新,有索引的情况下执行更快。

    1.2K40

    【面试题精讲】mysql-update语句执行流程

    执行 update 语句时,MySQL 会根据条件筛选出需要更新的记录,然后逐行修改记录中的数据。 2. 为什么需要 update 语句? update 语句的存在,体现了数据库的动态性。...update 语句的执行流程大致如下: 解析 SQL 语句:对给定的 update 语句进行解析,提取表名、操作字段(列名)、更新值、条件等信息; 锁定表:为了保证数据的一致性,在 update...6. update 语句的缺点 数据一致性风险:在多用户并发操作的情况下,update 语句可能导致数据不一致,需要时刻注意事务及锁机制; 执行速度受影响:当更新的记录数量较大时,update...语句的执行速度可能会受到影响。...在多条件查询中,注意使用 合适的索引,以提高 update 语句的执行速度。

    33320

    【面试题精讲】mysql-update语句执行流程

    执行 update 语句时,MySQL 会根据条件筛选出需要更新的记录,然后逐行修改记录中的数据。 2. 为什么需要 update 语句? update 语句的存在,体现了数据库的动态性。...update 语句的执行流程大致如下: 解析 SQL 语句:对给定的 update 语句进行解析,提取表名、操作字段(列名)、更新值、条件等信息; 锁定表:为了保证数据的一致性,在 update...6. update 语句的缺点 数据一致性风险:在多用户并发操作的情况下,update 语句可能导致数据不一致,需要时刻注意事务及锁机制; 执行速度受影响:当更新的记录数量较大时,update...语句的执行速度可能会受到影响。...在多条件查询中,注意使用 合适的索引,以提高 update 语句的执行速度。

    22810

    MySQL数据库执行Update卡死问题解决

    执行数据库更新update操作的时候数据库卡死了 问题分析 一般都是数据库事务未提交,导致update或者delete卡死。...解决办法 在执行完更新或删除后,记得将事务提交commit; 找到数据库客户端,执行commit操作。 如果还不行。...那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。...update操作 update car set color ='银色' where id = 1; update car set color ='红色' where id = 1; 查询正在执行的事务:...正在等待锁)另一个是1089(update 正在执行 没有提交事务) 可以使用mysql命令杀掉线程:kill 线程id kill 1089; 期间如果并未杀掉持有锁的线程:则第二个update语句会提示等待锁超时

    2K20

    一条Update语句的执行过程是怎样的?

    前言通过本文主要了解Sql执行流程,包括两个问题:MySQL的一条Select语句是怎么运行的MySQL的一条Update语句是怎么运行的先看第一个问题,这里做个简单描述 ,因为我们着重还是看UpdateMySQL...优化阶段:基于查询成本的考虑, 选择查询成本最小的执行计划;执行阶段:根据执行计划执行 SQL 查询语句,从存储引擎读取记录,返回给客户端相对于Select,内容更多和更复杂的是Update语句的执行,...Update执行逻辑先把我画的图看完,图中步骤比较多,需要花点时间看,你想我画这个肯定花了更长时间,如果觉得还不错的话,谢谢点赞收藏下,不足的话大家指正下!...语句,对应一条相反的UPDATE的undo logBinLog 是Server实现的逻辑日志,用于复制和恢复数据,记录了所有的 DDL 和 DML 语句(除了数据查询语句select、show等)WAL...二阶段提交,顾名思义,会包含 2 个阶段:prepare 阶段,协调器会询问所有执行器,是否可以提交事务commit 阶段,协调器会通知执行器进行提交操作update执行阶段也用到了,比如:prepare

    50911
    领券