SQL优化工具

什么是索引?

  • 打个比方,我们在使用MySQL用作查询的时候就好比查字典,索引就好比字典的偏旁部首页。如果没有索引我们查询一个文字就需要一页页的翻,显然这种方式效率很低。如果我们对某一字段加入了索引,就可以通过偏旁部首页查找这个文字,让查询变得更加高效。

相关链接

效果展示

  1. SELECT
  2. ca_id,
  3. sub_id,
  4. ca_number,
  5. sub_number
  6. FROM
  7. tbl_category ca
  8. LEFT JOIN tbl_subcategory sub ON ca.ca_number = sub.sub_number

  • 使用SQL优化工具
  1. [root@localhost /]# /usr/sbin/sqladvisor -f /etc/sql.cnf -q "SELECT ca_id, sub_id, ca_number, sub_number FROM tbl_category ca LEFT JOIN tbl_subcategory sub ON ca.ca_number = sub.sub_number" -v 1
  2. 2017-08-15 19:27:43 3494 [Note] 1步: SQL解析优化之后得到的SQL:select `ca_id` AS `ca_id`,`sub_id` AS `sub_id`,`ca_number` AS `ca_number`,`sub_number` AS `sub_number` from (`test`.`tbl_category` `ca` left join `test`.`tbl_subcategory` `sub` on((`ca`.`ca_number` = `sub`.`sub_number`)))
  3. 2017-08-15 19:27:43 3494 [Note] 2步:开始解析join on条件:ca.ca_number=sub.sub_number
  4. 2017-08-15 19:27:43 3494 [Note] 3步:开始选择驱动表,一共有1个候选驱动表
  5. 2017-08-15 19:27:43 3494 [Note] explain select * from tbl_category
  6. 2017-08-15 19:27:43 3494 [Note] 4步:候选驱动表tbl_category的结果集行数为:29521
  7. 2017-08-15 19:27:43 3494 [Note] 5步:选择表tbl_category为驱动表
  8. 2017-08-15 19:27:43 3494 [Note] 6步:表tbl_category SQL太逆天,没有优化建议
  9. 2017-08-15 19:27:43 3494 [Note] 7步:开始验证 字段sub_number是不是主键。表名:tbl_subcategory
  10. 2017-08-15 19:27:43 3494 [Note] show index from tbl_subcategory where Key_name = 'PRIMARY' and Column_name ='sub_number' and Seq_in_index = 1
  11. 2017-08-15 19:27:43 3494 [Note] 8步:字段sub_number不是主键。表名:tbl_subcategory
  12. 2017-08-15 19:27:43 3494 [Note] 9步:开始验证 字段sub_number是不是主键。表名:tbl_subcategory
  13. 2017-08-15 19:27:43 3494 [Note] show index from tbl_subcategory where Key_name = 'PRIMARY' and Column_name ='sub_number' and Seq_in_index = 1
  14. 2017-08-15 19:27:43 3494 [Note] 10步:字段sub_number不是主键。表名:tbl_subcategory
  15. 2017-08-15 19:27:43 3494 [Note] 11步:开始验证表中是否已存在相关索引。表名:tbl_subcategory, 字段名:sub_number, 在索引中的位置:1
  16. 2017-08-15 19:27:43 3494 [Note] show index from tbl_subcategory where Column_name ='sub_number' and Seq_in_index =1
  17. 2017-08-15 19:27:43 3494 [Note] 12步:开始输出表tbl_subcategory索引优化建议:
  18. 2017-08-15 19:27:43 3494 [Note] Create_Index_SQLalter table tbl_subcategory add index idx_sub_number(sub_number)
  19. 2017-08-15 19:27:43 3494 [Note] 13步: 优化结束!
  1. 2017-08-15 19:27:43 3494 [Note] 12步:开始输出表tbl_subcategory索引优化建议:
  2. 2017-08-15 19:27:43 3494 [Note] Create_Index_SQLalter table tbl_subcategory add index idx_sub_number(sub_number)
  • 执行工具的索引优化建议

alter table tbl_subcategory add index idx_sub_number(sub_number)

  • 执行sql语句(耗时0.05秒左右[linux系统下的测试])
  1. SELECT
  2. ca_id,
  3. sub_id,
  4. ca_number,
  5. sub_number
  6. FROM
  7. tbl_category ca
  8. LEFT JOIN tbl_subcategory sub ON ca.ca_number = sub.sub_number

详细链接 : http://wangweihong.com

SQL优化工具的更多相关文章

  1. Oracle 10G强大的SQL优化工具:SQL Tuning Advisor

    p { margin-bottom: 0.25cm; direction: ltr; color: rgb(0, 0, 0); line-height: 120%; orphans: 2; widow ...

  2. SQL优化工具SQLAdvisor使用

    一.简介在数据库运维过程中,优化SQL是业务团队与DBA团队的日常任务.例行SQL优化,不仅可以提升程序性能,还能够降低线上故障的概率. 目前常用的SQL优化方式包括但不限于:业务层优化.SQL逻辑优 ...

  3. 美团SQL优化工具SQLAdvisor

    介绍 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 SQL 优化,不仅可以提升程序性能,还能够降低线上故障的概率. 目前常用的 SQL 优化方式包括但不限于:业务层优化.SQL逻 ...

  4. 美团开源 SQL 优化工具 SQLAdvisor

    https://www.oschina.net/news/82725/sqladvisor-opensource https://github.com/Meituan-Dianping/SQLAdvi ...

  5. sql优化工具--美团SQLAdvisor

    美团点评SQL优化工具SQLAdvisor开源 介绍 在数据库运维过程中,优化 SQL 是 DBA 团队的日常任务.例行 SQL 优化,不仅可以提升程序性能,还能够降低线上故障的概率. 目前常用的 S ...

  6. 【SQL优化】SQL优化工具

    SQLAdvisor 是由美团点评公司北京DBA团队开发维护的 SQL 优化工具:输入SQL,输出索引优化建议. 它基于 MySQL 原生词法解析,再结合 SQL 中的 where 条件以及字段选择度 ...

  7. SQL优化工具SQLAdvisor使用(转)

    一.简介 在数据库运维过程中,优化SQL是业务团队与DBA团队的日常任务.例行SQL优化,不仅可以提升程序性能,还能够降低线上故障的概率. 目前常用的SQL优化方式包括但不限于:业务层优化.SQL逻辑 ...

  8. 美团点评SQL优化工具SQLAdvisor开源快捷部署

    美团点评SQL优化工具SQLAdvisor开源快捷部署 git clone https://github.com/Meituan-Dianping/SQLAdvisor.gityum install ...

  9. 智能SQL优化工具--SQL Optimizer for SQL Server(帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 )

    SQL Optimizer for SQL Server 帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 SQL Optimizer for SQL Server 让 SQL Serve ...

随机推荐

  1. java循环

    .增强for循环和iterator遍历的效果是一样的,也就说增强for循环的内部也就是调用iteratoer实现的(可以查看编译后的文件),但是增强for循环 有些缺点,例如不能在增强循环里动态的删除 ...

  2. Java大数据人才应用领域广,就业薪酬高

    互联网创造了大数据应用的规模化环境,大数据应用成功的案例大都是在互联网上发生的, 互联网业务提供了数据,互联网企业开发了处理软件,互联网企业的创新带来了大数据应用 的活跃,没有互联网便没有今天的大数据 ...

  3. [补档]vijos1883 月光的魔法

    vijos1883 月光的魔法 题目 传送门:https://www.vijos.org/p/1883 背景 影几欺哄了众生了 天以外-- 月儿何曾圆缺   描述 有些东西就如同月光的魔法一般. Lu ...

  4. unable to create …

    问题描述: 在新建Android Application时会出现unable to create the selected property page 解决方法: 将用户PATH路径中的jdk路径放到 ...

  5. thymeleaf中的日期格式化

    本篇介绍些thymeleaf中的日期格式化的方法: 1.用#dates.format来解决: <span th:text="${#dates.format(user.date, 'yy ...

  6. Http跨域时的Option请求

    写这篇文章时,我们碰到的一个场景是:要给R系统做一个扩展小应用,前端的html.js放在R系统里,后端需要做一个单独的站点N.B.com.这就导致了跨域问题,而且要命的是,后端同学没有权限向招聘的系统 ...

  7. MongoDB安全策略

    一,修改启动端口 mongo的默认端口为27017 如果启用的是27017端口并且在公网上很容易被人攻击,所以第一点我们要修改端口 sudo ./mongod --dbpath=/data/db -- ...

  8. C语言开篇

    Linux下使用最广泛的C/C++编译器是GCC,大多数的Linux发行版本都默认安装,不管是开发人员还是初学者,一般都将GCC作为Linux下首选的编译工具. 1.小程序test_gets.c #i ...

  9. 关于JS的DOM操作——重要实例的操作

    1.复选框与按钮的配合使用的DOM操作 <body>                <input type="checkbox" id="ckb1&qu ...

  10. 学习笔记TF048:TensorFlow 系统架构、设计理念、编程模型、API、作用域、批标准化、神经元函数优化

    系统架构.自底向上,设备层.网络层.数据操作层.图计算层.API层.应用层.核心层,设备层.网络层.数据操作层.图计算层.最下层是网络通信层和设备管理层.网络通信层包括gRPC(google Remo ...