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

MySQL 的prepare使用中的bug解析过程

一、问题发现 二、问题调查过程 三、问题解决方案 四、问题总结 一、问题发现 在一次开发中使用 MySQL PREPARE 以后,从 prepare 直接取 name 赋值给 lex->prepared_stmt_name...然后给 EXECUTE 用,发现有一定概率找不到 prepare stmt 的 name,于是开始动手调查问题发生的原因。...SQL语句示例: CREATE TABLE t1 (a INT, b VARCHAR(10)); PREPARE dbms_sql_stmt4 FROM 'INSERT INTO t1 VALUES (...UU) given to EXECUTE 二、问题调查过程 1、根据报错信息找到对应源码,发现在MySQL_sql_stmt_execute里面有判断当找不到 stmt name 时候报错信息。...三、问题解决方案 通过以上 gdb 跟踪过程我们可以发现 prepare 存 name 的时候存放方式有问题导致 name 最后没有结束符,于是回头看一下set_name 的代码,于是发现以下代码问题:

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

    Mysql语句的执行过程

    《高性能MySQL》 衡量查询开销的三个指标 响应时间扫描的行数 服务时间(处理这条语句真正花的时间) 排队时间(等待资源,例如IO,行锁等) 扫描的行数 返回的行数 当删除了搜索条件列的索引时,语句进行全表扫描...当语句过长时,可能受到服务器端max_allowed_packet的限制。 服务器响应给用户的数据通常会很多,由多个数据包组成。(客户端不断接受服务器推送的数据,客户端没有办法让服务器停下来。...图二 语句的处理过程 1.连接数据库 客户端发起一条Query请求,监听客户端的‘连接管理模块’接收请求。 将请求转发到‘连接进/线程模块’。 调用‘用户模块’来进行授权检查。...2.处理请求 查询缓存 通过一个大小写敏感的哈希查找判断查询是否命中查询缓存的数据。 命中查询缓存,用户权限没有问题,MySQL直接从缓存中拿结果返回给客户端。...MySQL将结果集返回给客户端是一个逐步返回的过程;数据库开始产生第一个结果时,就可以开始向服务器返回结果集。 使用MySQL客户端、服务器通信协议进行封包。 通过Tcp协议传输数据。

    2.6K20

    数据库中的declare什么意思_mysql prepare语句

    比如说,这个存储过程是,只要你把学号输入进来,就能查询这个学生的班级。那么在这个存储过程里面, 学号就是参数。你给什么学号, 它就返回给你相应的班级。...又或者你也可以做成, 只要你输入学号, 这个存储过程就会将这个学生删除。 mysql存储过程中,定义变量有两种方式: 1.使用set或select直接赋值,变量名以 @ 开头....在存储过程中,使用动态语句,预处理时,动态内容必须赋给一个会话变量。...例: set @v_sql= sqltext; PREPARE stmt FROM @v_sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; 有的时候在查询更新数据库的时候...,需要多条语句的查询,因此需要多次修改 declare可以满足多次执行,但数据只修改一次。

    2.8K30

    MySQL十八:写语句的执行过程

    一、读语句的执行过程 在之前《MySQL运行机制》文中,详细说明了一个查询语句的执行的过程,查询sql的执行过程基本上分为六步: 「建立连接(Connectors&Connection Pool)」 「...IO问题的。...2.5 写入语句的执行过程 通过对以下的几篇文章的介绍,可以使我们对MySQL的写入有了一个大概的认识,内部的执行原理也有了比较清晰的认知,接下来看一下一条sql在执行的整个流程中,从它经历组件,各个组件做的操作等角度来分析一下写操作的执行过程...「存储引擎接收到name='张三'的数据之后,将其更新到内存中对应的数据页中,同时写入redo log日志中,但是redo log写入之后未提交,处于准备(prepare)阶段」。...「后台线程会定时将Buffer Pool中的修改过的缓存页加载到磁盘中」 通过以上执行过程分析图,写入操作就完成了,由此可见,虽然我们就写了一句update语句,但是实际上mysql还是帮助我们做了很多工作的

    2.5K20

    MySql的sql语句执行过程详述

    前言: 很多人都在使用mysql数据库,但是很少有人能够说出来整个sql语句的执行过程是怎样的,如果不了解执行过程的话,就很难进行sql语句的优化处理,也很难设计出来优良的数据库表结构。...这篇文章主要是讲解一下sql语句的执行过程。 sql语句的执行过程: 客户端、连接器、分析器、优化器、执行器、存储引擎几个阶段。 连接器的作用:管理链接、权限验证的处理。...存储引擎: 主要负责数据的存储和提取,其架构模式是插件式的,支持InnoDB、Memory等多个存储引擎。最常用的是InnoDB,这个主要在Mysql5.5版本开始成为了默认存储引擎。...分析器: 分析器首先会进行词法分析,输入的是由多个字符串和空格组成的一条sql语句,mysql需要识别出来里面的字符串分别是什么,代表什么意思。...优化器: 经过了分析器的处理,mysql就知道了该如何进行优化器的处理了,优化器的处理逻辑是在表里面进行多个索引的时候,决定使用那个索引,或者说在一个语句有多个关联的时候,决定各个表的连接顺序的情况,如下图所示

    31140

    MySQL Prepare后语句查询性能降低 源码bug排查分析

    源自于业务上遇到的一个先将某个语句Prepare再Execute查询效率很低的问题,而将查询中的参数直接嵌入到SQL语句内并以文本形式执行,则执行反而变得很快。...测试环境:腾讯云 MySQL 服务(txsql8.0.22)、MySQL 源码编译(refs/tags/mysql-8.0.22) 问题描述 背景 MySQL 中,语句执行有两种方式,分别是 Text...,同一个语句,Prepare/Execute模式的性能出现了明显降低,而文本SQL模式不受影响。...问题分析 由于执行的是同一个语句,排除了两种模式的RTT差异因素后,初步怀疑是「Prepare/Execute模式」和「文本SQL模式」下,优化器生成的执行计划出现了差异导致。...问题在于,这个检查在 Prepare/Execute 模式下,MySQL检查过严了,将 col1 = ? 中的占位符 ?

    1.5K50

    MySQL执行SQL语句过程详解

    开发人员基本都知道,我们的数据存在数据库中(目前最多的是MySQL和Oracle,由于作者更擅长MySQL,所以这里默认数据库为MySQL),服务器通过sql语句将查询数据的请求传入到MySQL数据库。...sql的解析器与预处理   sql解析器是在命令分发之后,将对应的sql语句,解析为sql解析树。sql解析树是MySQL本身内部的语法规则和解析查询。...rbo最大的问题在于,通过固定规则来决定执行计划。并不会考虑sql中涉及的对象的数量和分布。有可能选出来的规则不是最优的执行计划。   ...成本指的是MySQL根据相关的统计信息,算出来sql语句对应的io,cpu等的消耗的一个估计值。计算过程涉及到索引、表、行等数据,过程比较复杂。   ...执行完成后,将结果返回给客户端,如果是查询语句,并且开启了缓存,那么,MySQL会同时将结果集放到查询缓存中。然后将查到的结果集返回。如果是增删改操作,那么返回执行语句后受影响的行数。

    3.5K20

    【重学 MySQL】四十、SQL 语句执行过程

    【重学 MySQL】四十、SQL 语句执行过程 select 语句的完整结构 SELECT 语句是 SQL(Structured Query Language)中用于从数据库表中检索数据的核心语句...一个完整的 SELECT 语句结构可以包括多个部分,但并非所有部分都是必须的,具体取决于你想从数据库中检索什么信息。...GROUP BY(可选):将结果集中的行分组为一个或多个汇总行,每个分组包含列中值的集合。通常与聚合函数(如 COUNT, MAX, MIN, SUM, AVG)一起使用。...可以指定一个或多个列进行排序,以及排序的方向(升序 ASC 或降序 DESC)。 LIMIT(可选):限制返回的记录数。...当然如果我们操作的是两张以上的表,还会重复上面的步骤,直到所有表都被处理完为止。这个过程得到是我们的原始数据。

    14810

    细品mysql之Join 语句的执行过程

    背景 今天优化了一个,join关联查的语句,需要优化join的语句,那我们肯定得了解他的一个执行过程。正所谓知己知彼,百战百胜!! join的查询算法 1....Simple Nested-Loop Join(简单的嵌套循环连接) 简单嵌套循环算法的查询过程是嵌套查询,这个关联查询语句首先不能确定那个是驱动表,因为使用join的话,mysql的优化器会自己进行索引的选择...如果a 和 b字段 在都没有索引的情况下就会出现这种算法查询。 查询过程:先在t1表中将符合条件的字段a一条查出来然后遍历t2表遍历循环。(但是在mysql中并没有使用到这个算法) ?...那就是使用Block Nested-Loop Join这个算法 查询过程:把表 t1 的数据读入线程内存 join_buffer 中,由于我们这个语句中写的是 select *,因此是把整个表 t1...总结 讲了四种算法的大概查询过程 mysql 3种查询算法,有索引 BKA(join buffer) NLJ 没有索引 BLN (join buffer) 驱动表的选择,选择小的驱动表(参与joinbuffer

    1.1K32

    SQL语句distinct的多个字段去重问题

    将需要去重的字段添加到where条件中,取出唯一id 然后就可以获得去重之后的两个字段了 不过我这边是你需要去重一个字段,展示两个字段的情况 # 注意 有很多朋友问...,group by是可以对多字段进行去重的,但是我这里为什么还说不行呢?...我在这里统一描述下 由于时间比较早了,我大概记得当时的场景是:对一个字段进行去重,而需要取两个字段,这样的写法如下 select A,B from table group by A 但是group...by是不支持这种写法的,因为group by 和 select 中的字段必须保持一致 当前注意事项写于:2022年6月27日18:24:10 还可以看如下文章 Group_concat介绍与例子..._HashMap黑龙江分Map的博客-CSDN博客_group_concat mysql去重的最方便的两种方法_承影v的博客-CSDN博客_mysql去重 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人

    2.9K30

    MySQL:一条SQL语句的执行过程

    大多数时候不建议使用缓存,因为只要一个表更新,这个表上的所有缓存数据就会被清空了。对于那些经常更新的表来说,缓存命中率很低。MYSQL8版本直接将查询缓存的整块功能删掉了。...第三步:分析器 分析器首先会做“词法分析”,MYSQL会识别出SQL语句里面的字符串是什么以及代表什么。接下来就是“语法分析器”,分析SQL的语法问题。...打开表的时候,执行器就会根据表的引擎定义,去使用这个引擎提供的接口。 图片 一条update语句执行流程 update语句除了会执行上面的五步,还会涉及两个重要的日志模块。...binlog(归档日志) binlog属于server层的日志,是逻辑日志,记录的是这个语句的原始逻辑,比如给“id =1 的一行的某个字段+2”。...引擎将这行数据更新到内存中,同时将这个更新操作记录到redo log里,此时rodo log属于prepare状态。然后告知执行器执行完成了,随时可以提交事务了。

    24020

    MySQL数据库:SQL语句的执行过程

    一、客户端的MySQL驱动: 我们的系统在和 MySQL 数据库进行通信前,需要先和数据库建立连接,而这个功能就是由MySQL驱动底层帮我们完成的,建立完连接之后,我们只需要发送 SQL 语句就可以执行...如下图所示: 一次 SQL 请求就会建立一个连接,多个请求就会建立多个连接。...假设我们的系统是部署在 tomcat 容器中的, tomcat 是可以并发处理多个请求的,这就会导致多个请求会去建立多个连接,然后使用完再都去关闭,这样会有什么问题呢?...在优化过程中,经过的一系列运算是什么呢?...key是SQL语句,value是查询结果。我们将这个过程称为查询缓存! (2)Buffer Pool位于存储引擎层。

    3.6K10

    MySQL探秘(二):SQL语句执行过程详解

    昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...如果在一条SQL语句执行的过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句的执行速度。...优化器会根据优化规则对关系表达式进行转换,这里的转换是说一个关系表达式经过优化规则后会生成另外一个关系表达式,同时原有表达式也会保留,经过一系列转换后会生成多个执行计划,然后CBO会根据统计信息和代价模型...MySQL将结果集返回给客户端是一个增量、逐步返回的过程。在查询生成第一条结果时,MySQL就可以开始向客户端逐步返回结果集了。

    1.8K30

    MySQL探秘(二):SQL语句执行过程详解

    昔日庖丁解牛,未见全牛,所赖者是其对牛内部骨架结构的了解,对于MySQL亦是如此,只有更加全面地了解SQL语句执行的每个过程,才能更好的进行SQL的设计和优化。  ...SQL语句执行过程 查询缓存  MySQL查询缓存保存查询返回的完整结构。当查询命中该缓存时,MySQL会立刻返回结果,跳过了解析、优化和执行阶段。  ...如果在一条SQL语句执行的过程中将该语句对应的最终执行计划进行缓存,当相似的语句再次被输入服务器时,就可以直接使用已缓存的执行计划,从而跳过SQL语句生成执行计划的整个过程,进而可以提高语句的执行速度。...优化器会根据优化规则对关系表达式进行转换,这里的转换是说一个关系表达式经过优化规则后会生成另外一个关系表达式,同时原有表达式也会保留,经过一系列转换后会生成多个执行计划,然后CBO会根据统计信息和代价模型...MySQL将结果集返回给客户端是一个增量、逐步返回的过程。在查询生成第一条结果时,MySQL就可以开始向客户端逐步返回结果集了。

    5.4K10

    MySQL 有效利用 profile 分析 SQL 语句的执行过程

    在日常的工作中,我们通常要分析 SQL 语句的性能,通过会使用到执行计划,利用执行计划来分析 SQL 语句的性能,并进行相应的优化;本文将利用 profile 分析 SQL 语句的执行过程来辅助的分析...SQL 语句,做好优化; 分析 SQL 执行带来的开销是优化 SQL 的重要手段。...本文描述了如何使用 MySQL profile 以及利用 Performance_Schema 来查询 profile 的 SQL 执行过程的样例; 一、有关 profile 的描述 1、查看 profiling...query end:表示语句执行完毕了,但是还有一些后续工作没做完时的状态。...先切换到 performance_schema 下,这是 MySQL 新增的性能优化引擎,在 5.6 以前是关闭的,5.6, 5.7 中是默认开启的,5.7 切换的时候还会有一句提示: root@localhost

    4.8K31

    Mac 安装MySQL过程遇到的问题

    最近在学习mysql,下载安装的过程中发现dmg下载的非常慢。300多M,一上午都没有下载完成,之后一个快捷的方法。...mysql 启动的时候相信很多人会遇到这个问题 The server quit without updating PID file ?...我在网上找到的解决方案记录下 1、可能是/usr/local/mysql/data/mysql.pid文件没有写的权限 解决方法 :给予权限,执行 “chown -R mysql:mysql /var...解决方法:请在[mysqld]下设置这一行:datadir = /usr/local/mysql/data 5、skip-federated字段问题 解决方法:检查一下/etc/my.cnf文件中有没有没被注释掉的...---- 我的问题第2个,有已经存在的mysql进程。 但是问题是我怎么杀也杀不死,杀死之后就会重启。 ? 原来是我之前电脑已经安装过mysql,在这里把他关了,就行了。 ? 希望可以帮到你。

    1.8K20

    关于数据库Prepare返回指针的的问题

    先写问题,代码在下面。 写入数据库可以这么写: stmt,err:=db.Prepare(`insert into user_tb(userid,userNo) values (?,?)...但是如果把prepare和exec分开就会报错,在exec那里报错。...`) //这里把prepare返回的【*sql.Stmt】指针写给db的成员数据} 接下来用F2来做exec: func (db *Mssql) F2(){ db.stmt.exec(...然后是main: func main(){ var db Mssql db.open(巴拉巴拉)defer db.close()db.F1() //这里执行prepare,赋值给成员数据的stmtdb.F2...问题就是,db.prepare()返回的是一个指针,是不是这个语句所在函数执行完毕之后就会把指针所在的地址释放掉?所以造成后面想用的时候就出错了?如果是的话怎样才能让stmt成功传递呢?

    1.1K90
    领券