# 前言在某些特定的问题排查场景下,或者需要复现问题,我们可能需要开启general log 来查看 MySQL 实时运行的 SQL 语句,以此来缩小问题的范围。general log 会记录所有的SQL语句,无论语句是否正确执行或者是由于语法错误而终止执行。同时开启 general log 在实例负载比较大的情况下了能会对服务器性能产生影响,这里推荐一个好用的工具,它基于 MySQL 协议的抓包工具,实时抓取 MySQL Server 端的请求,并格式化输出。# 工具安装...
# 前言在某些特定的问题排查场景下,或者需要复现问题,我们可能需要开启general log 来查看 MySQL 实时运行的 SQL 语句,以此来缩小问题的范围。general log 会记录所有的SQL语句,无论语句是否正确执行或者是由于语法错误而终止执行。同时开启 general log 在实例负载比较大的情况下了能会对服务器性能产生影响,这里推荐一个好用的工具,它基于 MySQL 协议的抓包工具,实时抓取 MySQL Server 端的请求,并格式化输出。# 工具安装##...
MySQL还提供了异常处理语句,可以在触发某个错误或异常时执行特定的SQL语句,以避免错误引起的数据库损坏。在MySQL中,对流程控制的处理也可以很灵活。比如,在如果某条件符合的情况下,可以使用IF ELSE.. THENEND格式来执行某一API函数,从而实现不同的数据库动作,不同的数据处理方式,或者执行某个外部的语句。为了简化复杂的查询或流程控制,MySQL支持存储过程,允许用户存储一组SQL语句,并且在必要时可以重复执行。存储过程可以接...
# 问题描述 MySQL 5.7 的 SQL Modes 对 SQL 的检查更加严格和规范,会出现一些 SQL 兼容性问题。 # 问题分析 具体常见的问题包含以下几个方面:## 1.SQL查询的字段不包含在GROUP BY 语句中(ONLY_FULL_GROUP_BY)如果**SELECT**的字段与**GROUP BY**的字段不匹配,那么就会报错如下: ```MySQL [dbtest]> select min(update_time),name,id from tb_author group by name;ERROR 1055 (42000): Expression #3 of SELEC...
# 前言在某些特定的问题排查场景下,或者需要复现问题,我们可能需要开启general log 来查看 MySQL 实时运行的 SQL 语句,以此来缩小问题的范围。general log 会记录所有的SQL语句,无论语句是否正确执行或者是由于语法错误而终止执行。同时开启 general log 在实例负载比较大的情况下了能会对服务器性能产生影响,这里推荐一个好用的工具,它基于 MySQL 协议的抓包工具,实时抓取 MySQL Server 端的请求,并格式化输出。# 工具安装...
# 前言在某些特定的问题排查场景下,或者需要复现问题,我们可能需要开启general log 来查看 MySQL 实时运行的 SQL 语句,以此来缩小问题的范围。general log 会记录所有的SQL语句,无论语句是否正确执行或者是由于语法错误而终止执行。同时开启 general log 在实例负载比较大的情况下了能会对服务器性能产生影响,这里推荐一个好用的工具,它基于 MySQL 协议的抓包工具,实时抓取 MySQL Server 端的请求,并格式化输出。# 工具安装##...
MySQL还提供了异常处理语句,可以在触发某个错误或异常时执行特定的SQL语句,以避免错误引起的数据库损坏。在MySQL中,对流程控制的处理也可以很灵活。比如,在如果某条件符合的情况下,可以使用IF ELSE.. THENEND格式来执行某一API函数,从而实现不同的数据库动作,不同的数据处理方式,或者执行某个外部的语句。为了简化复杂的查询或流程控制,MySQL支持存储过程,允许用户存储一组SQL语句,并且在必要时可以重复执行。存储过程可以接...
# 问题描述 MySQL 5.7 的 SQL Modes 对 SQL 的检查更加严格和规范,会出现一些 SQL 兼容性问题。 # 问题分析 具体常见的问题包含以下几个方面:## 1.SQL查询的字段不包含在GROUP BY 语句中(ONLY_FULL_GROUP_BY)如果**SELECT**的字段与**GROUP BY**的字段不匹配,那么就会报错如下: ```MySQL [dbtest]> select min(update_time),name,id from tb_author group by name;ERROR 1055 (42000): Expression #3 of SELEC...
# 问题描述MySQL 5.7 的 SQL Modes 对 SQL 的检查更加严格和规范,会出现一些 SQL 兼容性问题。# 问题分析具体常见的问题包含以下几个方面:## 1.SQL查询的字段不包含在GROUP BY 语句中(ONLY_FULL_GROUP_BY)如果**SELECT**的字段与**GROUP BY**的字段不匹配,那么就会报错如下:````undefinedMySQL [dbtest]> select min(update_time),name,id from tb_author group by name;ERROR 1055 (42000): Expression #3 of SELECT li...
# 问题描述客户在含有自增主键的表格中成功插入数据后,使用73924 查询,发现返回值为 0# 问题分析因为默认会用到 MySQL 的连接池复用功能,不同语句不能保证一定在同一个连接上执行,所以会导致即使数据成功插入,但是后续查询返回值为 0 的异常。# 问题复现1.模拟批量的插入数据和73924的操作```bashfor i in `seq 10000`;do mysql -h rds-mysql-h2******.rds.ivolces.com -udemo -p******** -e "use dbtest;insert into exe...
为查询缓存优化你的查询大多数的 MySQL 服务器都开启了查询缓存。这是提高性最有效的方法之一,而且这是被 MySQL 的数据库引擎处理的。当有很多相同的查询被执行了多次的时候,这些查询结果会被放到一个缓存中,这样,后续的相同的查询就不用操作表而直接访问缓存结果了。这里最主要的问题是,对于程序员来说,这个事情是很容易被忽略的。因为,我们某些查询语句会让 MySQL 不使用缓存。MySQL 的查询缓存对这个函数不起作用。所以...
表空间碎片会影响数据库性能,这是因为 当 MySQL 进行数据扫描时,扫描的大小是表的容量需求上限,也就是数据被写入的区域中处于峰值的部分。对于 delete 操作来说,删除数据时只是在数据行打上 delete Mark 的标签,当下次进行插入时,这部分空间可以重用,但是如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片;# 如何查看表空间碎片1.使用 show table status 的命令进行查看:```sqlmysql> show ...
表空间碎片会影响数据库性能,这是因为 当 MySQL 进行数据扫描时,扫描的大小是表的容量需求上限,也就是数据被写入的区域中处于峰值的部分。对于 delete 操作来说,删除数据时只是在数据行打上 delete Mark 的标签,当下次进行插入时,这部分空间可以重用,但是如果某个空白空间一直没有被大小合适的数据占用,仍然无法将其彻底占用,就形成了碎片;# 如何查看表空间碎片1.使用 show table status 的命令进行查看:```sqlmysql> ...