?今天逛时,发现了这款对 SQL 进行优化和改写的自动化工具。感觉挺不错的,就下载学习了一下。这个工具支持的功能比较多,可以作为我们日常开发中的一款辅助工具,现在我就把它推荐给你们~~~ github传送门:https://github.com/XiaoMi/soar ?
在我们日常开发中,优化SQL总是我们日常开发任务之一。例行 SQL 优化,不仅可以提升程序性能,还能够降低线上故障的概率。
目前常用的 SQL 优化方式包括但不限于:业务层优化、SQL逻辑优化、索引优化等。其中索引优化通常通过调整索引或新增索引从而达到 SQL 优化的目的。索引优化往往可以在短时间内产生非常巨大的效果。如果能够将索引优化转化成工具化、标准化的流程,减少人工介入的工作量,无疑会大大提高我们的工作效率。
SOAR(SQL Optimizer And Rewriter) 是一个对 SQL 进行优化和改写的自动化工具。由小米人工智能与云平台的数据库团队开发与维护。
与业内其他优秀产品对比如下:
SOAR | sqlcheck | pt-query-advisor | SQL Advisor | Inception | sqlautoreview | |
---|---|---|---|---|---|---|
启发式建议 | ? | |||||
索引建议 | ? | ? | ? | |||
查询重写 | ? | ? | ? | ? | ? | |
执行计划展示 | ? | ? | ? | ? | ? | |
Profiling | ? | ? | ? | ? | ? | |
Trace | ? | ? | ? | ? | ? | |
SQL在线执行 | ? | ? | ? | ? | ? | |
数据备份 | ? | ? | ? | ? | ? |
从上图可以看出,支持的功能丰富,其功能特点如下:
就介绍这么多吧,既然是SQL优化工具,光说是没有用的,我们还是先用起来看看效果吧。
这里有两种安装方式,如下:
这里建议直接下载最新版,要不会有。
下载好的二进制文件添加到环境变量中即可(不会的谷歌一下吧,这里就不讲了)。
测试一下:
依赖环境:
高级依赖(仅面向开发人员)
生成二进制文件:
生成的二进制文件与上面一样,直接放入环境变量即可,这里我没有尝试,靠你们自己踩坑了呦~~~
准备一个,如下:
现在是完全根据SQL语句进行分析的,因为没有连接到。可以看到,给出的报告也很详细,但是只是空壳子,仅凭语句给出的分析并不是准确的,所以我们开始接下来的应用。
我们可以在配置文件中配置好相关的配置,操作如下:
配置好了,我们来实践一下子吧:
这回结果中多了EXPLAIN信息分析报告。这对于刚开始入门的小伙伴们是友好的,因为我们对解析的字段并不熟悉,有了它我们可以完美的分析中的问题,是不是很棒。
工具不仅仅可以进行语句分析,还可以进行对语法进行检查,找出其中的问题,来看个例子:
这里关键字少了一个,运行该指令帮助我们一下就定位了问题,当我们的语句很长时,就可以使用该指令来辅助我们检查语句是否正确。
我们日常开发时,经常会看其他人写的代码,因为水平不一样,所以有些语句会写的很乱,所以这个工具就派上用场了,我们可以把我们的语句变得漂亮一些,更容易我们理解哦。
这样看起来是不是更直观了呢~~。
因为我也才是刚使用这个工具,更多的玩法我还没有发现,以后补充。更多玩法可以自己研究一下,github传送门:https://github.com/XiaoMi/soar。官方文档其实很粗糙,更多方法解锁还要靠自己研究,毕竟源码已经给我们了,对于学习也有一定帮助,当作一个小项目慢慢优化岂不是更好呢~~。
「好啦,这一篇文章到这就结束了,我们下期见~~。希望对你们有用,又不对的地方欢迎指出,我们一起学习交流。」
版权所有:Copyright © 2002-2017 欧陆平台-欧陆娱乐-注册登录中心 版权所有 粤IP**********