新特性解读 | 针对用户定制不同格式执行计划

news/2024/7/23 11:24:49 标签: 执行计划输出格式, MySQL 8.0 新特性

作者:杨涛涛

资深数据库专家,专研 MySQL 十余年。擅长 MySQL、PostgreSQL、MongoDB 等开源数据库相关的备份恢复、SQL 调优、监控运维、高可用架构设计等。目前任职于爱可生,为各大运营商及银行金融企业提供 MySQL 相关技术支持、MySQL 相关课程培训等工作。

本文来源:原创投稿

*可生开源社区出品,原创内容未经授权不得随意使用,转载请联系小编并注明来源。


记得以前在项目现场时,客户曾提出一个这样的需求:在 MySQL 数据库里查看语句的执行计划,能否针对不同的用户使用同样的语句定制输出不同的格式?比如用户张三不想执行 explain format=‘tree’ ,只想简单执行 explain就可以输出tree 格式的执行计划;同样用户李四也不想执行 explain format=‘json’ ,只想简单执行 explain就可以输出 json 格式的执行计划。

好吧!当时MySQL 没有提供这样的功能,而且我也觉得这样的功能非必需,于是我给了三个可选方法:
第一: 自己写个脚本对 MySQL 客户端进行封装;
第二:建议直接用 SHELL 来调用 MySQL 客户端,并且定制类似 SHELL 的别名;
第三:别偷懒…。
最后经过一系列探讨,客户选择了选项三!

不过幸运的是,最新版本 MySQL 8.0.32 最近发布,提供了这样的功能。用一个变量来针对不同的用户可以定制输出不同格式的执行计划,变量名为:explain_format 。通过设置不同的值,来使得 explain 语句 输出不同格式的执行计划。

我们来体验下这个功能:
设置默认格式为 tree 。
mysql:8.0.32-cluster:ytt>set @@explain_format=tree;
Query OK, 0 rows affected (0.00 sec)

<mysql:8.0.32-cluster:ytt>explain table t1\G
*************************** 1. row ***************************
EXPLAIN: -> Table scan on t1  (cost=1.20 rows=2)

1 row in set (0.00 sec)
设置默认格式为 traditional ,也就是传统模式。
mysql:8.0.32-cluster:ytt>set @@explain_format=traditional;
Query OK, 0 rows affected (0.00 sec)

<mysql:8.0.32-cluster:ytt>explain table t1\G
*************************** 1. row ***************************
           id: 1
  select_type: SIMPLE
        table: t1
   partitions: NULL
         type: ALL
possible_keys: NULL
          key: NULL
      key_len: NULL
          ref: NULL
         rows: 2
     filtered: 100.00
        Extra: NULL
1 row in set, 1 warning (0.00 sec)
有了这个功能,就仿佛奥特曼看到了光。 那接下来,我们来实现本篇开头的需求:语句相同,用户不同,执行计划的输出格式不同。

新建两个用户,一个是 zhangsan ,另外一个是 lisi 。zhangsan 的执行计划格式为:explain format=‘tree’ ; lisi 的执行计划格式为:explain format=‘json’ 。

分别创建这两个用户:

mysql:8.0.32-cluster:ytt>create user zhangsan;
Query OK, 0 rows affected (0.00 sec)

<mysql:8.0.32-cluster:ytt>create user lisi;
Query OK, 0 rows affected (0.01 sec)

<mysql:8.0.32-cluster:ytt>grant select on ytt.* to zhangsan;
Query OK, 0 rows affected (0.01 sec)

<mysql:8.0.32-cluster:ytt>grant select on ytt.* to lisi;
Query OK, 0 rows affected (0.01 sec)

用户 zhangsan 连接 MySQL 后,自动设置执行计划格式:

root@ytt-super:/home/ytt# mysql -uzhangsan --init-command='set @@explain_format=tree' -D ytt
...
<mysql:8.0.32-cluster:ytt>explain table t1\G
*************************** 1. row ***************************
EXPLAIN: -> Table scan on t1  (cost=1.20 rows=2)

1 row in set (0.00 sec)

同样的方法,用户 lisi 则这样连接 MySQL :结果太长,我就不贴了。

root@ytt-super:/home/ytt# mysql -ulisi --init-command='set @@explain_format=json' -D ytt

http://www.niftyadmin.cn/n/49276.html

相关文章

微信小程序开发你可能不知道的开发技巧

1. 页面级data&#xff0c;组件data的查看 页面级data的查看&#xff0c;很多开发者应该都知道&#xff1b;组件级的数据查看我是开发了大半年才发现的&#xff1b; 页面级的data查看&#xff1a; 组件的data查看&#xff1a; 2. 放大模拟器【调整一些UI细节】 效果&#x…

【LeetCode】石子游戏 IV [H](动态规划)

1510. 石子游戏 IV - 力扣&#xff08;LeetCode&#xff09; 一、题目 Alice 和 Bob 两个人轮流玩一个游戏&#xff0c;Alice 先手。 一开始&#xff0c;有 n 个石子堆在一起。每个人轮流操作&#xff0c;正在操作的玩家可以从石子堆里拿走 任意 非零 平方数 个石子。 如果石…

上海亚商投顾:三大指数均涨超1% 芯片板块集体大涨

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。市场情绪三大指数今日低开高走&#xff0c;午后集体涨超1%&#xff0c;创业板指盘中涨超1.7%。芯片板块集体大涨&#xff0c;…

mac:彻底解决-安装应用后提示:无法打开“XXX”,因为无法验证开发者的问题;无法验证此App不包含恶意软件

mac从浏览器或其他电脑接收了应用&#xff0c;但是打开报错 目录报错解决办法一次性方法永久解决方法验证恢复应用验证报错 截图如下&#xff1a; 错误信息 无法打开“XXX”&#xff0c;因为无法验证开发者的问题&#xff1b;无法验证此App不包含恶意软件 解决办法 一次性方…

linux Ubuntu KUbuntu 系统安装相关

系统安装 本来想快到中午的时候调试一下服务器上的http请求接收代码。我的电脑上装的是kali的U盘系统&#xff0c;然后我的U盘居然找不到了(然后之前安装的系统不知道是否是写入软件的原因&#xff0c;没办法解析DNS,我都用的转发的,这让我体验非常差。kali的系统工具很多&…

【C++】nullptr C++中的空指针(C++11)

前言 在平时我们写C/C代码时你可能会看到有人使用NULL表示空指针&#xff0c;也有人用nullptr表示空指针&#xff0c;那么你可能会很好奇它们都是空指针吗&#xff1f;为什么空指针有两种写法&#xff1f;下面就带你了解这背后的原理。 我们都知道NULL是C语言中的空指针&#x…

作为研发如何使用Github Api?

文章目录使用步骤账号创建进行开发者相关设置API操作演示Github API好处推荐的Github API&#x1f31f;个人主页: 个人主页 &#x1f6b5;‍♀️个人介绍:每天进步一点点&#xff0c;生活变得好一点点。 &#x1f4cc;作为一位开发&#xff0c;不管是非工作的还是工作中的人士&…

软件测试】测试时间不够了,我很慌?项目马上发布了......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 常见的几种情况&…