MySQL数据库调优————OPTIMIZER_TRACE详解

news2024/11/26 4:11:55

OPTIMIZER_TRACE是MySQL5.6引入的一项跟踪功能,它可以跟踪优化器做出的各种决策(比如访问表的方法、各种开销计算、各种转换等),并将跟踪结果记录到INFORMATION_SCHEMA.OPTIMIZER_TRACE表中。此功能默认关闭,开启后 ,可分析如下语句:

  • SELECT
  • INSERT
  • REPLACE
  • UPDATE
  • DELETE
  • EXPLAIN
  • SET
  • DECLARE
  • CASE
  • IF
  • RETURE
  • CALL

OPTIMIZER_TRACE相关参数

  • optimizer_trace
    • optimizer_trace:总开关,默认值:enabled=off,one_line=off
    • enabled:是否开启optimizer_trace;on表示开启,off表示关闭
    • one_line:是否开始单行存储。on表示开始,off表示关闭,将会用标准的JSON格式化存储。设置成on将会有良好的格式,设置成off可节省一些空间。
  • optimizer_trace_features
    • 控制optimizer_trace跟踪的能容,默认值:greedy_search=on,reage_optimizer=on,dynamic_range=on,repeated_subselect=on,表示开启所有的追踪项。
    • greedy_search:是否跟踪贪心搜索。
    • range_optimizer:是否跟踪范围优化器。
    • synamic_range:是否跟踪动态范围优化。
    • repeated_subselect:是否跟踪子查询,如果设置成off,只跟踪第一条Item_subselect的执行。
  • optimizer_trace_limit:控制optimizer_trace展示多少条结果,默认1
  • optimizer_trace_max_mem_size:optimizer_trace堆栈信息允许的最大内存,默认1048576
  • optimizer_trace_offset:第一个要展示的optimizer_trace的偏移量,默认-1
  • end_markers_in_json:如果JSON结构很大,则很难将右括号和左括号配对。为了帮助阅读,可将其设置成on,这样会在右括号附件加上注释,默认off

TIPS

  • 以上参数可用SET语句操作,例如,用如下命令即可打开OPTIMIZER_TRACE
    SET OPTIMIZER_TRACE=“enabled=on”,END_MARKERS_IN_JSON=on;
    也可用SET GLOBAL全局开启。但即使全局开启OPTIMIZER_TRACE,每个session也只能跟踪自己执行的语句:
    SET GLOBAL OPTIMIZER_TRACE=“enabled”,END_MARKERS_IN_JSON=on;
  • optimizer_trace_limit和optimizer_trace_offset这两个参数经常配合使用,例如:
    SET optimizer_trace_offset=< OFFSET >,optimizer_trace_limit=< LIMIT >
    这两个参数配合使用,有点儿类似MySQL里面的limit语句。
    默认情况下,由于optimizer_trace_offset=-1,optimizer_trace_limit=1,记录最近的一条SQL语句,展示时,每次展示1条数据;
    如果改成SET optimizer_trace_offset=-2,optimizer_trace_limit=1,则会记录倒数第二条SQL语句。

OPTIMIZER_TRACE使用

  • 开始OPTIMIZER_TRACE功能,并设置要展示的数据条目数:
    SET OPTIMIZER_TRACE="enabled=on",END_MARKERS_IN_JSON=on;
    SET optimizer_trace_offset=-30,optimizer_trace_limit=30;
    
  • 发送你想要分析的查询语句,例如:
    select * from salaries where from_date = '1986-06-26';
    
  • 使用如下语句分析,即可获得类似如下的结果:
  • 在这里插入图片描述
    在QUERY列找到自己执行的语句,将TRACE中的内容复制到JSON文件中,并对其过程进行分析。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/345830.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

工业智能网关解决方案:物联网仓储环境监测系统

仓储是连接生产、供应和销售的中转系统&#xff0c;对于促进生产、提高效率有着重要的辅助作用。对于很多大型工厂或食品厂来说&#xff0c;需要对仓储环境进行严控的控制&#xff0c;以确保产品或食品的质量&#xff0c;避免不必要的产品损耗&#xff0c;提高产品存管的水平。…

Redisson分布式锁基本使用及可重入锁原理分析

基本使用 1、引入依赖 <!-- redisson依赖 --><dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>3.13.6</version></dependency>2、配置redisson客户端 // 将RedissonClie…

【每日随笔】手指训练 ( 手指训练作用 | 哪些人需要手指训练 | 手指操 | 手指康复训练器材 )

文章目录一、手指训练作用二、哪些人需要手指训练三、手指操四、手指康复训练器材产品需求探索 , 研究下手指训练的市场 , 前景 , 是否可以开发 ; 一、手指训练作用 手指训练作用 : 改善 上肢协调性手眼 协调性训练提高 手指 抓握 能力提高 手指 灵活性提高 上肢运动 准确性 和…

vscode下进行python配置及编码,新手学习

介绍在开发工具vscode下进行python的配置及编码&#xff0c;新手来学。 1、首先下载及安装最新版本的vscode。 【VSCode最新版本下载安装详细教程&#xff08;win10)】 2、下载安装最新版本python&#xff0c;也可以根据需要下载自己需要的版本。 【python3.11下载安装详细…

基于Web的6个完美3D图形WebGL库

现代前端、游戏和Web开发正是WebGL可以转化为数字杰作的东西。使用GPU绘制在浏览器屏幕上生成的矢量元素&#xff0c;WebGL创建交互式Web图形&#xff0c;从而获得用户体验。视觉元素的质量和复杂性使该工具在HTML或CSS等其他方法中脱颖而出。WebGL基础WebGL不是一个图形套件。…

电脑录屏用什么软件?推荐这3款软件,用过都说好

如今网络中&#xff0c;有很多的软件都能够实现电脑录屏。但想要找一个方便好用的电脑录屏软件却十分困难。电脑录屏用什么软件&#xff1f;今天小编将为小伙伴分享3款超级方便好用的电脑录屏软件&#xff0c;用过的小伙伴都说好&#xff01;一起来看看吧。 电脑录屏软件1&…

即时通讯为组织构建移动平台的规划和效益分析

随着移动通信、移动互联网、云计算等新技术的快速发展&#xff0c;移动信息化已成为应用软件发展的重要趋势。传统的固定办公模式&#xff0c;限制了工作人员办事的灵活性&#xff0c;降低了办事效率&#xff1b;随着办事“移动性”越来越高&#xff0c;出差越来越频繁&#xf…

线程互斥、同步

目录 一、线程互斥 1.1 相关概念介绍 1.2 互斥量mutex 1.3 互斥量接口 1.4 互斥量实现原理 二、可重入与线程安全 2.1 概念 2.2 常见线程不安全的情况 2.3 常见线程安全的情况 2.4 常见不可重入的情况 2.5 常见可重入的情况 2.6 可重入与线程安全的关系 三、死锁 …

MySql分表、分库、分片和分区的区别

一、前言 数据库的数据量达到一定程度之后&#xff0c;为避免带来系统性能上的瓶颈。需要进行数据的处理&#xff0c;采用的手段是分区、分片、分库、分表。 二、分片&#xff08;类似分库&#xff09; 分片是把数据库横向扩展&#xff08;Scale Out&#xff09;到多个物理节…

链表题目总结 -- 迭代

目录一. 反转链表1. 思路简述2. 代码3. 总结二. K 个一组翻转链表1. 思路简述2. 代码3. 总结一. 反转链表 题目链接&#xff1a;https://leetcode.cn/problems/reverse-linked-list/ 1. 思路简述 三个指针进行迭代&#xff0c;pre指向前驱&#xff0c;cur是当前指针&#xf…

Python requests模块

一、requests模块简介 requests模块是一个第三方模块&#xff0c;需要在python环境中安装&#xff1a; pip install requests 该模块主要用来发送 HTTP 请求&#xff0c;requests 模块比 urllib 模块更简洁。 requests模块支持&#xff1a; 自动处理url编码自动处理post请求…

软件工程(5)--喷泉模型

前言 这是基于我所学习的软件工程课程总结的第五篇文章。 迭代是软件开发过程中普遍存在的一种内在属性。经验表明&#xff0c;软件过程各个阶段之间的迭代或一个阶段内各个工作步骤之间的迭代&#xff0c;在面向对象范型中比在结构化范型中更常见。 一般说来&#xff0c;使用…

新闻稿怎么发?影响发稿价格的因素

在当今的信息化社会&#xff0c;新闻稿是传播信息的重要手段&#xff0c;在企业、大众媒体、政府机构以及其他组织中都广泛使用新闻稿来向外界发布信息。但是&#xff0c;发布新闻稿既要求新闻稿内容准确&#xff0c;又要求要有良好的发布形式&#xff0c;这就要求发布者要懂得…

专用舆情监测服务公司,TOOM舆情监测公司排名全国

舆情监测公司是专门从互联网、传媒等渠道搜集信息&#xff0c;对与客户相关的信息进行筛选、分析和报告&#xff0c;帮助客户及时了解和掌握舆情动态&#xff0c;保障客户的声誉和利益&#xff0c;专用舆情监测服务公司&#xff0c;TOOM舆情监测公司排名全国。 一、专用舆情监…

Win10系统不需要的服务项怎么删除?

Win10系统不需要的服务项怎么删除&#xff1f;在使用电脑的时候&#xff0c;里面会有一些不需要的服务项目。比如一些我们以前安装的软件&#xff0c;卸载之后的服务项残留等等。那么如何去进行不需要的服务项删除呢&#xff1f;一起来看看具体的方法分享吧。 操作教程 1、首先…

【C++提高笔记】泛型编程与STL技术

文章目录模板的概念函数模板函数模板语法函数模板注意事项函数模板案例普通函数与函数模板的调用规则模板的局限性类模板类模板语法类模板与函数模板区别类模板中成员函数创建时机类模板对象做函数参数类模板与继承类模板成员函数类外实现类模板分文件编写类模板与友元类模板案…

从源码角度解析SpringMVC执行流程

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到网站。 SpringMVC执行流程在面试中经常会被问到&#xff0c;本篇文章通过源码的方式简单的了解一下SpringMVC执行流程。 先看流程 先看一下Sp…

基于java的一款实时聊天系统,包含服务端 + 客户端 + web端

最终效果为什么先看最终效果&#xff1f;因为此刻代码已经撸完了。更重要的是我们带着感官的目标去进行后续的分析&#xff0c;可以更好地理解。标题中提到了&#xff0c;整个工程包含三个部分&#xff1a;1、聊天服务器聊天服务器的职责一句话解释&#xff1a;负责接收所有用户…

图像去噪技术简述

随着每天拍摄的数字图像数量激增&#xff0c;对更准确、更美观的图像的需求也在增加。然而&#xff0c;现代相机拍摄的图像不可避免地会受到噪声的影响&#xff0c;从而导致视觉图像质量下降。因此&#xff0c;需要在不丢失图像特征&#xff08;边缘、角和其他尖锐结构&#xf…

基于RK3399+YOLO目标检测人工智能图像系统设计

随着 5G 通信技术的大范围普及&#xff0c;传统的目标检测系统已经不再能满足如今步入智 能化的各行各业的需求。消费者对以往依靠机器学习的传统目标检测系统提出了更高的 要求&#xff0c;相关的生产企业也开始向智能化和低功耗化过渡。其中如何将图像增强技术、目 标检测技术…