广告
返回顶部
首页 > 资讯 > 数据库 >Mysql优化神器(推荐)
  • 705
分享到

Mysql优化神器(推荐)

Mysql优化 2022-05-21 03:05:21 705人浏览 安东尼
摘要

前言 今天逛GitHub时,发现了这款对 sql 进行优化和改写的自动化工具sora。感觉挺不错的,就下载学习了一下。这个工具支持的功能比较多,可以作为我们日常开发中的一款辅助工具,现在我就把它推荐给你们~~~ g

前言

今天逛GitHub时,发现了这款对 sql 进行优化和改写的自动化工具sora。感觉挺不错的,就下载学习了一下。这个工具支持的功能比较多,可以作为我们日常开发中的一款辅助工具,现在我就把它推荐给你们~~~

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在线执行 ✔️
数据备份 ✔️

从上图可以看出,支持的功能丰富,其功能特点如下:

  • 跨平台支持(支持 linux, Mac 环境,windows 环境理论上也支持,不过未全面测试
  • 目前只支持 Mysql 语法族协议的 SQL 优化
  • 支持基于启发式算法的语句优化
  • 支持复杂查询的多列索引优化(UPDATE, INSERT, DELETE, SELECT)
  • 支持 EXPLaiN 信息丰富解读
  • 支持 SQL 指纹、压缩和美化
  • 支持同一张表多条 ALTER 请求合并
  • 支持自定义规则的 SQL 改写

就介绍这么多吧,既然是SQL优化工具,光说是没有用的,我们还是先用起来看看效果吧。

安装

这里有两种安装方式,如下:

下载二进制安装包


$ wget Https://github.com/XiaoMi/soar/releases/download/0.11.0/soar.linux-amd64 -O soar
chmod a+x soar

这里建议直接下载最新版,要不会有bug。

下载好的二进制文件添加到环境变量中即可(不会的谷歌一下吧,这里就不讲了)。

测试一下:


$ echo 'select * from user' | soar.darwin-amd64(根据你自己的二进制文件名来输入)
# Query: AC4262B5AF150CB5
 
★ ★ ★ ☆ ☆ 75分
 
```sql
SELECT
 *
FROM
 USER
```
 
## 最外层 SELECT 未指定 WHERE 条件
 
* **Item:** CLA.001
 
* **Severity:** L4
 
* **Content:** SELECT 语句没有 WHERE 子句,可能检查比预期更多的行(全表扫描)。对于 SELECT COUNT(\*) 类型的请求如果不要求精度,建议使用 SHOW TABLE STATUS 或 EXPLAIN 替代。
 
## 不建议使用 SELECT * 类型查询
 
* **Item:** COL.001
 
* **Severity:** L1
 
* **Content:** 当表结构变更时,使用 \* 通配符选择所有列将导致查询的含义和行为会发生更改,可能导致查询返回更多的数据。

源码安装

依赖环境:

Go 1.10+
2. git

高级依赖(仅面向开发人员)

  • mysql 客户端版本需要与容器中MySQL版本相同,避免出现由于认证原因导致无法连接问题
  • Docker MySQL Server测试容器管理
  • govendor Go包管理
  • retool 依赖外部代码质量静态检查工具二进制文件管理

生成二进制文件:

go get -d github.com/XiaoMi/soar
cd ${GOPATH}/src/github.com/XiaoMi/soar && make
生成的二进制文件与上面一样,直接放入环境变量即可,这里我没有尝试,靠你们自己踩坑了呦~~~

简单使用

0. 前置准备

准备一个table,如下:


CREATE TABLE `users` (
 `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
 `username` varchar(64) NOT NULL DEFAULT '',
 `nickname` varchar(255) DEFAULT '',
 `passWord` varchar(256) NOT NULL DEFAULT '',
 `salt` varchar(48) NOT NULL DEFAULT '',
 `avatar` varchar(128) DEFAULT NULL,
 `uptime` datetime DEFAULT NULL,
 PRIMARY KEY (`id`),
 UNIQUE KEY `username` (`username`)
) ENGINE=InnoDB AUTO_INCREMENT=11 DEFAULT CHARSET=utf8mb4

1. 直接输入sql语句(不运行)


$ echo "select * from users" | soar.darwin-amd64
$ # Query: 30AFCB1E1344BEBD
 
★ ★ ★ ☆ ☆ 75分
 
```sql
SELECT
 *
FROM
 users
```
## 最外层 SELECT 未指定 WHERE 条件
 
* **Item:** CLA.001
 
* **Severity:** L4
 
* **Content:** SELECT 语句没有 WHERE 子句,可能检查比预期更多的行(全表扫描)。对于 SELECT COUNT(\*) 类型的请求如果不要求精度,建议使用 SHOW TABLE STATUS 或 EXPLAIN 替代。
 
## 不建议使用 SELECT * 类型查询
 
* **Item:** COL.001
 
* **Severity:** L1
 
* **Content:** 当表结构变更时,使用 \* 通配符选择所有列将导致查询的含义和行为会发生更改,可能导致查询返回更多的数据。

现在是完全根据SQL语句进行分析的,因为没有连接到mysql。可以看到,给出的报告也很详细,但是只是空壳子,仅凭SQL语句给出的分析并不是准确的,所以我们开始接下来的应用。

2. 连接mysql生成EXPLAIN分析报告

我们可以在配置文件中配置好mysql相关的配置,操作如下:


vi soar.yaml
# yaml fORMat config file
online-dsn:
  addr:   127.0.0.1:3306
  schema:  asong
  user:   root
  password: root1997
  disable: false
 
test-dsn:
  addr:   127.0.0.1:3306
  schema:  asong
  user:   root
  password: root1997
  disable: false

配置好了,我们来实践一下子吧:


$ echo "SELECT id,username,nickname,password,salt,avatar,uptime FROM users WHERE username = 'asong1111'" | soar.darwin-amd64 -test-dsn="root:root1997@127.0.0.1:3306/asong" -allow-online-as-test -log-output=soar.log
$ # Query: D12A420193AD1674
 
★ ★ ★ ★ ★ 100分
 
```sql
SELECT
 id, username, nickname, PASSWORD, salt, avatar, uptime
FROM
 users
WHERE
 username = 'asong1111'
```
 
## Explain信息
 
| id | select\_type | table | partitions | type | possible_keys | key | key\_len | ref | rows | filtered | Scalability | Extra |
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | SIMPLE | *users* | NULL | const | username | username | 258 | const | 1 | ☠️ **100.00%** | ☠️ **O(n)** | NULL |
 
### Explain信息解读
 
#### SelectType信息解读
 
* **SIMPLE**: 简单SELECT(不使用UNION或子查询等).
 
#### Type信息解读
 
* **const**: const用于使用常数值比较PRIMARY KEY时, 当查询的表仅有一行时, 使用system. 例:SELECT * FROM tbl WHERE col = 1.

这回结果中多了EXPLAIN信息分析报告。这对于刚开始入门的小伙伴们是友好的,因为我们对Explain解析的字段并不熟悉,有了它我们可以完美的分析SQL中的问题,是不是很棒。

3. 语法检查

soar工具不仅仅可以进行sql语句分析,还可以进行对sql语法进行检查,找出其中的问题,来看个例子:


$ echo "selec * from users" | soar.darwin-amd64 -only-syntax-check
At SQL 1 : line 1 column 5 near "selec * from users" (total length 18)

这里select关键字少了一个t,运行该指令帮助我们一下就定位了问题,当我们的sql语句很长时,就可以使用该指令来辅助我们检查SQL语句是否正确。

4. SQL美化

我们日常开发时,经常会看其他人写的代码,因为水平不一样,所以有些SQL语句会写的很乱,所以这个工具就派上用场了,我们可以把我们的SQL语句变得漂亮一些,更容易我们理解哦。


$ echo "SELECT id,username,nickname,password,salt,avatar,uptime FROM users WHERE username = 'asong1111'" | soar.darwin-amd64 -report-type=pretty
 
SELECT
 id, username, nickname, PASSWORD, salt, avatar, uptime
FROM
 users
WHERE
 username = 'asong1111';

这样看起来是不是更直观了呢~~。

结尾

因为我也才是刚使用这个工具,更多的玩法我还没有发现,以后补充。更多玩法可以自己研究一下,github传送门:https://github.com/XiaoMi/soar。官方文档其实很粗糙,更多方法解还要靠自己研究,毕竟源码已经给我们了,对于学习go也有一定帮助,当作一个小项目慢慢优化岂不是更好呢~~。

到此这篇关于Mysql优化神器(推荐)的文章就介绍到这了,更多相关Mysql优化内容请搜索自学编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持自学编程网!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql优化神器(推荐)

本文链接: https://www.lsjlt.com/news/10038.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mysql优化神器(推荐)
    前言 今天逛github时,发现了这款对 SQL 进行优化和改写的自动化工具sora。感觉挺不错的,就下载学习了一下。这个工具支持的功能比较多,可以作为我们日常开发中的一款辅助工具,现在我就把它推荐给你们~~~ g...
    99+
    2022-05-21
    Mysql 优化
  • mysql优化文章(推荐)
    ref:http://www.javaeye.com/topic/144033作者:andyao原文link: http://andyao.javaeye.com/admin/show/144033转载请留...
    99+
    2022-10-18
  • 推荐一款MySQL优化工具
    之前韩锋老师写过一篇关于查看MySQL执行计划的文章,里面解释了一个脚本,是他早先定制的一个还不错的功能。 如何用一款小工具大大加速MySQL SQL语句优化(附源码) 使用细节在文章里介绍...
    99+
    2022-10-18
  • vue3 api自动导入神器推荐
    目录1. vue3 自动导入2. API 的 自动引入 ( 尤雨溪 推荐神器)3. 组件的自动引入 ( 尤雨溪 推荐神器)总结1. vue3 自动导入 原理 : 预加载前,该插件自动...
    99+
    2023-02-27
    vue导入功能 导入vue.js vue3 api自动导入
  • MySQL可视化工具推荐
    为方便使用MySQL,本文列举出几个MySQL的可视化工具,各位可各取所需! 1、MyDB Studio 该工具包含MySQL服务管理的完整工具集,功能比较强大,但是是收费的,且...
    99+
    2022-10-18
  • MySQL优化常用的19种有效方法(推荐!)
    目录1、EXPLAIN2、SQL语句中IN包含的值不应过多3、SELECT语句务必指明字段名称4、当只需要一条数据的时候,使用limit 15、如果排序字段没有用到索引,就尽...
    99+
    2022-11-13
  • 【Mysql】免费的mysql图形化软件推荐
    以下是几个推荐的免费MySQL图形化软件: phpMyAdmin:这是一个非常流行的MySQL管理工具,提供了一个基于Web的界面,可以方便地管理和操作MySQL数据库。 DBeaver Community:DBeaver是一个通用的数据...
    99+
    2023-10-05
    mysql 数据库 sql
  • 实时数据处理神器!Python API 学习笔记推荐
    在当今的信息时代,数据处理已经成为了各个行业的重要工作之一。而随着大数据技术的逐渐成熟,实时数据处理已经成为了越来越多企业和个人的需求。而 Python 作为一门高效的编程语言,其强大的数据处理能力更是被越来越多人所认可。本文将为大家介绍...
    99+
    2023-11-08
    api 学习笔记 实时
  • MySQL的性能优化神器Explain如何使用
    小编给大家分享一下MySQL的性能优化神器Explain如何使用,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!简介MySQL 提供了一个 EXPLAIN 命令, 它可以对 SELECT...
    99+
    2022-10-18
  • 详谈redis优化配置和redis.conf说明(推荐)
    1. Redis.conf 配置参数: #是否作为守护进程运行 daemonize yes #如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pid pidfile redis.p...
    99+
    2022-06-04
    优化配置 redis conf
  • Vue项目打包优化实践指南(推荐!)
    目录业务背景项目打包时间分析方法优化配置的基本思路前置操作,先通过 webpack-bundle-analyzer 查看资源树1.vue.config.js 文件中修改:produc...
    99+
    2022-11-13
  • MySQL性能优化神器Explain的基本使用分析
    简介 MySQL 提供了一个 EXPLAIN 命令, 它可以对 SELECT 语句进行分析, 并输出 SELECT 执行的详细信息, 以供开发人员针对性优化. EXPLAIN 命令用法十分简单,...
    99+
    2022-10-18
  • 方舟生存进化云服务器推荐
    在选择服务器之前,需要了解一下各个服务器的特点和优势。普通服务器的优势在于其价格便宜,容易上手,而且能够提供较为稳定的游戏环境。而高级服务器则提供更高级别的游戏环境和更强大的游戏体验,同时也需要付费。vr服务器则可以让你体验到更加真实的游戏...
    99+
    2023-10-28
    方舟 服务器
  • MySQL提升大量数据查询效率的优化神器
    目录前言查看SQL执行频率 定位低效率执行SQLexplain分析执行计划trace分析优化器执行计划使用索引优化SQL优化大量插入数据优化insert语句优化order by语句2、两种排序方式3、Files...
    99+
    2022-07-06
    MySQL提升大量数据查询效率 MySQL优化神器
  • Mysql性能优化之索引下推
    索引下推(index condition pushdown )简称ICP,在Mysql5.6的版本上推出,用于优化查询。 在不使用ICP的情况下,在使用非主键索引(又叫普通索引或者二级索引)进行查询时,存储引擎通过索...
    99+
    2022-05-19
    Mysql 索引下推
  • 数据库-三范式优化与不推荐使用外键
    反三范式其实是基于三范式所调整的,没有冗余的数据库未必是最好的数据库,完全按照第三范式做表的设计可能会降低查询效率(涉及多表查询,多表连接JOIN,临时表创建GROUP BY),有时候为了提高运行效率,就必须降低范式的标准...
    99+
    2016-12-01
    数据库-三范式优化与不推荐使用外键
  • 赞!推荐一款 Python 神器,不写一行代码,就可以调用 Matplotlib 绘图!
    介绍一款新的绘图神器:sviewgui。sviewgui介绍此 GUI 基于 matplotlib,您可以通过多种方式可视化您的 csv 文件。主要特点: Ⅰ 散点图、线图、密度图、直方图和箱线图类型; Ⅱ 标记大小、线宽、直方图的 bin...
    99+
    2023-05-14
    代码 Python Matplotlib
  • MySQL查询性能优化索引下推
    目录前言1. 索引下推的作用2. 案例实践3. 索引下推配置4. 索引下推原理剖析5. 索引下推应用范围前言 前面已经讲了mysql的其他查询性能优化方式,没看过可以去了解一下: MySQL查询性能优化七种方式索引潜水 ...
    99+
    2022-08-16
    MySQL查询性能优化 MySQL索引下推
  • Mysql性能优化:什么是索引下推?
    导读 本文章始发于本人公众号:码猿技术专栏,原创不易,谢谢关注推荐。 索引下推(index condition pushdown )简称ICP,在Mysql5.6的版本上推出,用于优化查询。 在不使用ICP的情况下,在使用...
    99+
    2018-12-31
    Mysql性能优化:什么是索引下推?
  • 阿里云服务器香港XN4优势、价格与推荐
    随着互联网的快速发展,云计算服务已成为企业运营的重要组成部分。作为中国领先云计算服务提供商,阿里云自2015年推出香港服务器XN4以来,受到了广大用户的一致好评。本文将详细分析香港XN4服务器的优势、价格以及推荐情况,帮助您更好地选择适合自...
    99+
    2023-11-07
    阿里 香港 优势
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作