从简单Sql探索优化之道

本文需要优化的语句是select count(*) from t,这简单的统计语句一出,估计不少人纳闷了,能有啥优化空间,还优化之道,什么gui。

 

哦,其实简单的背后不简单,来,跟作者一起看看如何“不择手段”,让count(*) 飞起来。不过我们用意的关键是让读者去思考,为什么能飞。

 

为什么能飞?嗯,因为我们掌握了Sql优化之道。那优化之道是什么?不着急,来,随我们来看看Sql飞的过程吧。

 

一 、优化过程

 

 

1. 普通思路

 

用了啥手段:啥没用!

 

 

性能啥情况:逻辑读为1048。

 

2. 增加索引

 

用了啥手段:建了一个btree索引。

 

 

性能啥情况:逻辑读从1048减少到372。

 

3. 位图索引

 

用了啥手段:建了一个位图索引。

 

 

性能啥情况:逻辑读从372瞬间缩减为6。

 

简单地说说位图索引的结构,比如T表有4个字段,分别是ID、NAME、SEX和STATUS,其中SEX取值仅为男或女,有时由于不知道性别,暂时为空,具体如下:

 

 

4. 物化视图

 

用了啥手段:应用了物化视图。

 

 

性能啥情况:逻辑读从6缩减为3。

 

说明:这主要是应用在数据库更新不是非常频繁场景,用的是空间换时间。

 

5. 缓存结果集

 

用了啥手段: 利用缓存结果集技术。

 

 

性能啥情况:逻辑读从3缩减为0。

 

在11g中,Oracle提供了结果集缓存特性。该缓存是在共享内存中存储全部的结果集,如果一个查询SQL被执行,且它对应的结果集在缓存中,那么,该SQL的几乎全部开销都可以避免。

 

6. 业务理解迎来速度之王

 

用了啥手段: 做了一件很奇怪的事,似乎把Sql改写的看不懂了。

 


select count(*) from t where rownum=1;

 


 

和下面的逻辑是等价的。

 


 

性能啥情况:表不管多大,永远只访问第1条,速度问题还需要纠结吗? 

 

二 、优化总结

 

 

 

三、总结

 
 

这本是一个简单的语句,却可以神奇的完成一次又一次优化,性能不断提升,优化过程涵盖了Sql执行计划和索引的理解、根据不同场景选择不同技术、根据业务进行等价改写这三大技巧,可谓非常的经典。简单的背后不简单,充满了人生的智慧,还请多多体会。

 

哦,还没说,Sql优化之道是什么?嗯,请看下面:

  • 优化知识本身+根据场景选择技术+把握业务需求!

 

作者介绍:梁敬彬

  • 【DBA+社群】数据库专家。
  • 福富研究院副理事长;福富软件特级专家。
  • 公司四星级内训师、ITPUB版主及ITPUB社区专家,十余年数据库设计调优及培训相关经验,多次应邀参加中国数据库技术大会任演讲嘉宾。
  • 此外还著有多本畅销数据库技术书籍,其代表作《收获,不止Oracle》极为畅销,上市3个月内就完成第3次印刷。新书《从菜鸟到Sql优化大师》即将上市......


时间: 2024-10-29 21:31:59

从简单Sql探索优化之道的相关文章

每秒执行6000的简单SQL优化(一)

    最近看到一个系统的负载比较高,引起了我的注意,查看AWR报告发现,竟然是因为两条很简单的SQL语句导致.     语句有多简单呢,就是下面的两个SQL语句. select companyname from license select supdepid from hrmdepartment where id =''     突然发现以前也发现了这个问题,但是最后也是不了了之,还是因为单纯从数据库的层面调整要灵活快捷的多,从业务层面来推动还是有一定的难度和阻力.之前的分析:关于CPU使用率

你对SQL性能优化知识知多少?

转自:http://www.vaikan.com/what-do-you-know-about-sql-performance/  "SQL性能优化是一种黑魔法 就像炼金术一样: 各种配方难解晦涩, 只有一小部分圈内人才能理解." 这是一种误解,SQL数据库使用的是大家公知的算法来实现可以预期的执行性能.然而,问题是,人们很容易写出不能发挥最高效算法的SQL查询语句,因而也容易产生无法预期的性能结果. 下面是5道关于SQL性能优化小测试题,这些测试题也许会让你坚信SQL优化就是一种黑魔

关联-关于oracle中查询sql的优化

问题描述 关于oracle中查询sql的优化 在数据库中的某个表中有几百万条数据,现在要用这张表关联别的表去查询,查询速度很慢,如何优化才能使查询速度快一些. 解决方案 先优化SQL,然后再优化业务逻辑.最后优化数据库数据存储.起码得把SQL贴出来看看吧,几百万的数据不算多呀. 解决方案二: oracle的权值查询 解决方案三: 用一个相关联的ID,直接查那个表,这样就简单了!

八大案例,带你参透SQL Server优化

在本文中,石沫针对用户遇到的各种实际问题,从实例层次到架构,通过8个SQL Server优化案例,分享了如何用最简单快捷的方式解决用户使用SQL Server数据库过程中的典型问题,使SQL Server能够稳定地提供持续服务. 以下是整理内容. 瓶颈诊断 工欲善其事,必先利其器.常见的分析性能问题的工具有三种:诊断硬件资源,等待类型,性能语句. 硬件资源通常有四个方面判断: CPU监控,性能计数器主要包括%Processor Time.Processor Queue Length.Batch

SQL Server 优化---为什么索引视图(物化视图)需要with(noexpand)强制查询提示

原文:SQL Server 优化---为什么索引视图(物化视图)需要with(noexpand)强制查询提示   本文出处:http://www.cnblogs.com/wy123/p/6694933.html    第一次通过索引视图优化SQL语句,以及遇到的一些问题,记录一下.   语句分析 最近开发递交过来一个查询统计的SQL,说是性能有问题,原本执行需要4-5秒钟,这个业务本身对性能要求又比较critical,期望是在1s之内在用尽各种办法之后(执行计划,统计信息,索引,改写SQL,临时

ORACLE性能优化之SQL语句优化

文章来源:http://blog.csdn.net/jdzms23/article/details/23850783 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] SQL语句执行过程 1 SQL语句的执行步骤 2 典型SELECT语句完整的执行顺序 3 SQL语句执行过程 优化器及执行计划 1 SQL优化方法论 合理应用Hints 1Hints 索引及应用实例 1什么是索引 2索引分类 3什么时候使用索引 4改写SQL使用索引 5索引应用 其他优化技术及应用 1其他优化

Sql效能优化总结与sql语句优化篇

今晚继续进行Sql效能问题的分享,今天主要是一些具体的sql优化方法和思路分享,若看过后你也有其他想法,欢迎一起探讨,好了,进入今天的主题.   针对性地对一些耗资源严重的具体应用进行优化   出现效能问题时,首先要做的是什么?这个问题我问过不少同事,有人说凭经验对出问题的sql进行优化,如我们一般说的要合理使用索引,尽量不要使用前面带*号的Like语句,不要再比较操作符前边进行计算或使用函数等等,这些道路都是对的,但经验有时候不一定能解决问题.问题出现时,首先要做的是确定问题点是什么,只有正确

SQL语句优化提升整体效能

针对性地对一些耗资源严重的具体应用进行优化 出现效能问题时,首先要做的是什么?这个问题我问过不少同事,有人说凭经验对出问题的sql进行优化,如我们一般说的要合理使用索引,尽量不要使用前面带*号的Like语句,不要再比较操作符前边进行计算或使用函数等等,这些道路都是对的,但经验有时候不一定能解决问题.问题出现时,首先要做的是确定问题点是什么,只有正确的找到问题后才能有针对性的解决问题.下面简单介绍我们一般从哪些角度入手,来确定问题所在. 1.首先从业务上理解该处功能,理解用户的真正意图,用户真正关

SQL Server优化技巧之SQL Server中的"MapReduce"

原文:SQL Server优化技巧之SQL Server中的"MapReduce" 日常的OLTP环境中,有时会涉及到一些统计方面的SQL语句,这些语句可能消耗巨大,进而影响整体运行环境,这里我为大家介绍如何利用SQL Server中的"类MapReduce"方式,在特定的统计情形中不牺牲响应速度的情形下减少资源消耗. 我们可能经常会利用开窗函数对巨大的数据集进行分组统计排序.比如下面的例子: 脚本环境 /* This script creates two new