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

MySQL Update执行流程解读

一、update跟踪执行配置 使用内部程序堆栈跟踪工具path_viewer,跟踪mysql update 一行数据的执行过程,配置执行脚本:call_update.sh DROP DATABASE...(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...row_update_for_mysql row_upd_step row_upd --执行更新 btr_pcur_t::restore_position rec_get_offsets_func...三、执行总结 update执行流程 1.执行语句连接数据库 2.分析器通过词法、语法分析知道这是一条更新语句 3.优化器确定执行路径 4.执行器具体执行,找到这一行,更新数据,然后通过Inodb存储具体更新操作

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

MySQL Update语句是怎么执行的?

MySQL Update语句是怎么执行的?...其实,update语句的执行过程和select语句差不多,但是在update语句执行的过程中,MySQL新增加了两个重要的日志模块,他们分别是redo log(重做日志)和binlog(二进制日志、也可以称之为归档日志...当我们执行一个update的SQL时,MySQL会干如下几件事情: a、执行器查找指定记录,如果记录所在的数据页在内存中,就直接返回给执行器;否则,需要先从磁盘读入内存,然后再返回。...b、执行器拿到Innodb存储引擎接口给的数据,执行update操作,得到新的数据,然后调用Innodb存储引擎的接口写入数据。...然后告知执行执行完成了,随时可以提交事务。 d、执行器生成update操作的binlog,并把binlog写入磁盘。

4.2K40

MySQL 执行 update 报错 ERROR 1292 说起

执行 update 报错 ERROR 1292 ,欢迎点击上方蓝字“JiekeXu DBA之路”关注我的公众号,标星或置顶,更多干货第一时间到达!...事情是这样的,上周五下班前通过自动化工具执行开发人员事先写好的 SQL 时,自动化工具执行失败了,于是手动去生产环境执行,就发生了错误 “ERROR 1292 (22007): Truncated incorrect...mysql> update t_busi_cont set busi_contract_file='ba42cfdb-a1d0-4e5a-c' and busi_contract_file_ct=1...上面图中“update t set id=‘6’ and c=‘6’ where d=1;”和“update t set id=‘6’ and c=‘1’ where d=1;” 都执行成功了,但是更新成功的值却不一样...c=‘1’ 的结果被认为是 假,故更新成 id=0 了(但是具体为啥会是这个结果呢,还是没搞明白,如果有大神看到可以不吝赐教),但是在生产环境中则出现了我下图中错误 数据类型匹配 而报错,只是这报错提示有点让人摸不着头脑

31620

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

test set score = 3 where id = 2; update语句也需要经过连接器、分析器、优化器、执行器,但是update语句相比select语句还是有很大不同的,更新流程设计两个重要的日志模块...innodb_flush_log_at_trx_commit:将该参数设置为1(默认值为1),设置为1以后,表示每次事务的redo log都直接持久化到磁盘,从而保证MySQL异常重启数据丢失 正常运行的实例数据落盘和...真正的将日志写入到redo log文件(ib_logfile+数字)是在执行commit语句的时候执行。...sync_binlog:将该参数设置为1(默认值为1),设置为1以后表示每次事务的binlog都会持久化到磁盘,从而保证MySQL异常重启后binlog丢失。 binlog的形式有几种?...UPDATE语句的执行流程 update test set score = 3 where id = 2; 整个update语句中牵涉到写redo log和binlog,并且redo log在前,binlog

1.6K10

MySQL客户端执行生效???

线上的一次MySQL事务问题记录 上周五进行了一个大表删除的操作,在删除的过程中,出现了一点小问题,白白花费了两个小时,我这里记录了一下大概的过程,废话不多说了,直接看过程吧。...然后重新使用mysql客户端登录进去,发现了一个奇怪的问题: [dba_mysql ~]$ /usr/local/mysql/bin/mysql -udba_admin -p -h127.0.0.1 -...我们知道,mysql加载配置文件有一个顺序,我们可以使用mysql --help|grep my.cnf的命令来查看,经过查看,是因为/etc/my.cnf中的配置也是autocommit=0,所以就把当前这个配置文件的参数给覆盖了...,最终,改完/etc/my.cnf文件中的autocommit参数内容之后,重新连接mysql服务器,发现问题解决。...组中的参数是用来控制mysql客户端的配置的。

3.3K40

MySQL事务的性情很“原子“,要么执行要么执行

另外可重复读是MySQL默认的事务隔离级别。 SERIALIZABLE(可串行化):该隔离级别会强制事务串行执行,同时对读取的每一行数据都加上锁,来。...可以采用我提到的SERIALIZABLE(可串行化)隔离级别来解决幻读,事务按顺序执行,也就不会有幻读问题。 MySQL也提供了其他方法来处理幻读问题。...是这样的,死锁是因为多个事务互相占用对方请求的资源导致的现象,要打破这个问题需要回滚其中一个事务,这样另一个事务就能获得请求资源了,而回滚的事务只需要重新执行即可。...有的,MySQL默认隔离级别是可重复读,企业生产一般也是用的这个隔离级别。

10121

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

执行数据库更新update操作的时候数据库卡死了 问题分析 一般都是数据库事务未提交,导致update或者delete卡死。...那么应该是数据库在执行数据操作失败 or 事务未提交 之后,将需要执行的sql语句锁死了。...update操作 update car set color ='银色' where id = 1; update car set color ='红色' where id = 1; 查询正在执行的事务:...SELECT * FROM information_schema.INNODB_TRX; 根据图中事务的线程ID(trx_mysql_thread_id)可以看出对应的mysql 线程:一个1084...(update正在等待锁)另一个是1089(update 正在执行 没有提交事务) 可以使用mysql命令杀掉线程:kill 线程id kill 1089; 期间如果并未杀掉持有锁的线程:则第二个update

1.8K20

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

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

16710

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

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

14020

一文看懂MySQL执行update更新语句的流程

binlog MySQL Server层,它主要做的是MySQL功能层面的事情 引擎层,负责存储相关的具体事宜 粉板redo log是InnoDB引擎特有的日志,而Server层也有自己的日志,称为...看执行器和InnoDB引擎在执行这个简单的update语句时的内部流程。 执行器先找引擎取id=2这行。id是主键,引擎直接用b+树搜索。...假设当前ID=2的行,字段c的值是0,再假设执行update语句过程中,在写完第一个日志后,第二个日志还没有写完期间发生crash?...建议设成1,保证MySQL异常重启之后数据丢失 sync_binlog这个参数设置成1的时候,表示每次事务的binlog都持久化到磁盘。...建议设成1,保证MySQL异常重启之后binlog丢失 参考 MySQL 实战 45 讲

3.2K10

MySQL insert or update sql

MySQL 一条 sql 实现数据保存变更 insert or update ,如果没有执行insert,有就update 需要 有主键 PRIMARY 或 唯一索引 UNIQUE MySQL...中的INSERT … ON DUPLICATE KEY UPDATE语句,该语句是基于唯一索引或主键使用 ON DUPLICATE KEY UPDATE后面可以放多个字段,用英文逗号分割。...`num_true`=4, `grade`=20, `time_sub`=NOW(), `time_do`=200; 上面语句亲测可用,但有一个警告 共 2 行受到影响, 1 个警告 执行耗时...插入……对于具有多个唯一密钥的表的重复密钥更新是不安全的 相关博客:https://blog.csdn.net/rick_zyl/article/details/79024612 mysql 有就更新...本站仅提供信息存储空间服务,拥有所有权,承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

2.6K20

MySQL的SELECT …for update

如果采用锁,那么操作方法如下: //1.查询出商品信息 select status from t_goods where id=1; //2.根据商品信息生成订单 insert into t_orders...要使用悲观锁,我们必须关闭mysql数据库的自动提交属性。 set autocommit=0;   //设置完autocommit后,我们就可以执行我们的正常业务了。...拿上面的实例来说,当我执行select status from t_goods where id=1 for update;后。...补充:MySQL select…for update的Row Lock与Table Lock   上面我们提到,使用select…for update会把数据给锁住,不过我们需要注意一些锁的级别,MySQL...InnoDB默认Row-Level Lock,所以只有「明确」地指定主键,MySQL 才会执行Row lock (只锁住被选取的数据) ,否则MySQL 将会执行Table Lock (将整个数据表单给锁住

3.7K30
领券