有个徒弟问我,要创建一个索引,去优化一个SQL,可是创建了索引之后其它 SQL 也要用 这个索引,其它SQL慢死了。要优化的SQL又快。遇到这样的问题咋搞?

一般遇到这样的问题还是非常少的。处理的方法非常多。我简单的给大家介绍一种方法。

还是直接看我实验操作步骤吧。

  1. SCOTT账户里面创建一个測试表和一个索引
  2. SQL> create table test as select * from dba_objects;
  3.  
  4. 表已创建。
  5. SQL> create index idx_test on test(object_id);
  6.  
  7. 索引已创建。
  1. SQL> set lines 200 pages 200
  2. SQL> set autot trace
  3. SQL> select * from test where object_id=10;
  4. 运行计划
  5. ----------------------------------------------------------
  6. Plan hash value: 2473784974
  7. ----------------------------------------------------------------------------------------
  8. | Id  | Operation                   | Name     | Rows  | Bytes | Cost (%CPU)| Time     |
  9. ----------------------------------------------------------------------------------------
  10. |   0 | SELECT STATEMENT            |          |     1 |   207 |     2   (0)| 00:00:01 |
  11. |   1 |  TABLE ACCESS BY INDEX ROWID| TEST     |     1 |   207 |     2   (0)| 00:00:01 |
  12. |*  2 |   INDEX RANGE SCAN          | IDX_TEST |     1 |       |     1   (0)| 00:00:01 |
  13. ----------------------------------------------------------------------------------------
  14. Predicate Information (identified by operation id):
  15. ---------------------------------------------------
  16.    2 - access("OBJECT_ID"=10)
  17. Note
  18. -----
  19.    - dynamic sampling used for this statement (level=6)
  20. 统计信息
  21. ----------------------------------------------------------
  22.          44  recursive calls
  23.           0  db block gets
  24.         136  consistent gets
  25.           4  physical reads
  26.           0  redo size
  27.        1404  bytes sent via SQL*Net to client
  28.         420  bytes received via SQL*Net from client
  29.           2  SQL*Net roundtrips to/from client
  30.           0  sorts (memory)
  31.           0  sorts (disk)
  32.           1  rows processed
  33. 然后人工设置索引统计信息 把集群银子搞大(很大)
  34. SQL> begin
  35.   2    dbms_stats.set_index_stats(ownname  => 'SCOTT',
  36.   3                               indname  => 'IDX_TEST',
  37.   4                               numrows  => 100000000000,
  38.   5                               numlblks => 100000,
  39.   6                               numdist  => 100000,
  40.   7                               avglblk  => 100000,
  41.   8                               avgdblk  => 100000,
  42.   9                               clstfct  => 100000000000);
  43.  10  end;
  44.  11  /
  45. PL/SQL 过程已成功完毕。
  46.  
  47. SQL> select * from test where object_id=10;
  48. 运行计划
  49. ----------------------------------------------------------
  50. Plan hash value: 1357081020
  51. --------------------------------------------------------------------------
  52. | Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
  53. --------------------------------------------------------------------------
  54. |   0 | SELECT STATEMENT  |      |     1 |   207 |   290   (1)| 00:00:04 |
  55. |*  1 |  TABLE ACCESS FULL| TEST |     1 |   207 |   290   (1)| 00:00:04 |
  56. --------------------------------------------------------------------------
  57. Predicate Information (identified by operation id):
  58. ---------------------------------------------------
  59.    1 - filter("OBJECT_ID"=10)
  60. Note
  61. -----
  62.    - dynamic sampling used for this statement (level=6)
  63. 统计信息
  64. ----------------------------------------------------------
  65.           0  recursive calls
  66.           0  db block gets
  67.        1039  consistent gets
  68.           0  physical reads
  69.           0  redo size
  70.        1404  bytes sent via SQL*Net to client
  71.         420  bytes received via SQL*Net from client
  72.           2  SQL*Net roundtrips to/from client
  73.           0  sorts (memory)
  74.           0  sorts (disk)
  75.           1  rows processed
  76. 这个时候。全部的SQL都不会走这个索引了,你想让某个SQL走索引。直接hint 让它走就ok

  77. SQL> select /*+ index(test idx_test) */ * from test where object_id=10;
  78. 运行计划
  79. ----------------------------------------------------------
  80. Plan hash value: 2473784974
  81. ----------------------------------------------------------------------------------------
  82. | Id  | Operation                   | Name     | Rows  | Bytes | Cost (%CPU)| Time     |
  83. ----------------------------------------------------------------------------------------
  84. |   0 | SELECT STATEMENT            |          |     1 |   207 |  1446K  (1)| 04:49:20 |
  85. |   1 |  TABLE ACCESS BY INDEX ROWID| TEST     |     1 |   207 |  1446K  (1)| 04:49:20 |
  86. |*  2 |   INDEX RANGE SCAN          | IDX_TEST |     1 |       |    15  (94)| 00:00:01 |
  87. ----------------------------------------------------------------------------------------
  88. Predicate Information (identified by operation id):
  89. ---------------------------------------------------
  90.    2 - access("OBJECT_ID"=10)
  91. Note
  92. -----
  93.    - dynamic sampling used for this statement (level=6)
  94. 统计信息
  95. ----------------------------------------------------------
  96.           0  recursive calls
  97.           0  db block gets
  98.           4  consistent gets
  99.           0  physical reads
  100.           0  redo size
  101.        1404  bytes sent via SQL*Net to client
  102.         420  bytes received via SQL*Net from client
  103.           2  SQL*Net roundtrips to/from client
  104.           0  sorts (memory)
  105.           0  sorts (disk)
  106.           1  rows processed

  107. 这样还没完,由于要是有人收集了统计信息,会覆盖我们set的统计信息,所以收集完统计信息之后,要再跑一下那个set的统计信息就ok了。

怎样让索引仅仅能被一个SQL使用的更多相关文章

  1. 如何让索引只能被一个SQL使用

    有个徒弟问我,要创建一个索引,去优化一个SQL,但是创建了索引之后其他 SQL 也要用 这个索引,其他SQL慢死了,要优化的SQL又快.遇到这种问题咋搞? 一般遇到这种问题还是很少的.处理的方法很多. ...

  2. 自己实现一个SQL解析引擎

    自己实现一个SQL解析引擎 功能:将用户输入的SQL语句序列转换为一个可运行的操作序列,并返回查询的结果集. SQL的解析引擎包含查询编译与查询优化和查询的执行,主要包含3个步骤: 查询分析: 制定逻 ...

  3. Oracle数据库该如何着手优化一个SQL

    这是个终极问题,因为优化本身的复杂性实在是难以总结的,很多时候优化的方法并不是用到了什么高深莫测的技术,而只是一个思想意识层面的差异,而这些都很可能连带导致性能表现上的巨大差异. 所以有时候我们应该先 ...

  4. 一个 Sql语句优化的问题- STATISTICS 统计信息

    前段时间,同事遇到一个 Sql语句的问题,一个列表分页功能响应在30 s以上,看数据库里面的数据条数,数据量也不大,相关字段的一些索引也都有,可就是慢.于是找出具体的sql 语句出来分析,分页功能主要 ...

  5. SqlServer 中如何查看某一个Sql语句是复用了执行计划,还是重新生成了执行计划

    我们知道SqlServer的查询优化器会将所执行的Sql语句的执行计划作缓存,如果后续查询可以复用缓存中的执行计划,那么SqlServer就会为后续查询复用执行计划而不是重新生成一个新的执行计划,因为 ...

  6. Android怎样保证一个线程最多仅仅能有一个Looper?

    1. 怎样创建Looper? Looper的构造方法为private,所以不能直接使用其构造方法创建. private Looper(boolean quitAllowed) { mQueue = n ...

  7. 给隔壁的妹子讲『一个SQL语句是如何执行的?』

    前言 SQL作为Web开发是永远离开不的一个话题,天天写SQL,可是你知道一个SQL是如何执行的吗? select name from user where id = 1; 上面是一个简单的查询语句, ...

  8. MySQL GROUP_CONCAT函数使用示例:如何用一个SQL查询出一个班级各个学科第N名是谁?

    如何用一个SQL查询出一个班级各个学科第N名是谁? 首先贴出建表语句,方便大家本地测试: -- 建表语句 CREATE TABLE score ( id INT NOT NULL auto_incre ...

  9. 用scala实现一个sql执行引擎-(上)

    前言 在实时计算中,通常是从队列中收集原始数据,这种原始数据在内存中通常是一个java bean,把数据收集过来以后,通常会把数据落地到数据库,供后面的ETL使用.举个一个简单的例子,对一个游戏来说, ...

随机推荐

  1. XT800 在域环境在运行设置

    测试时先将防火墙关了,不然无法远程,找个问题后再打开防火墙 0. 防火墙中建立规则,允许XT800通过. 1.在客户端当前用户下运行XT800安装程序 2.输入管理员账号及密码 3.安装时选择D或E盘 ...

  2. ping 原理及ICMP协议简介

    //Ping IP/域名 public static String pingIPCennect(String ipStr) {  String result = "";  if ( ...

  3. ES6学习笔记(九)Set和Map数据结构

    1.set 基本等于Java的Set集合类型,无序不可重复集,常被用来去重. 基本用法 const s = new Set();//通过Set()构造函数创建 [2, 3, 5, 4, 5, 2, 2 ...

  4. or in 、Object.keys()以及Object.getOwnPropertyNames有什么区别?

    or in .Object.keys()以及Object.getOwnPropertyNames的区别 var obj= Object.create(parent, { b: { value: 2, ...

  5. GCJ1C09C - Bribe the Prisoners

    GCJ1C09C - Bribe the Prisoners Problem In a kingdom there are prison cells (numbered 1 to P) built t ...

  6. CSUOJ 1555 Inversion Sequence

    1555: Inversion Sequence Time Limit: 2 Sec  Memory Limit: 256 MBSubmit: 107  Solved: 34 Description ...

  7. RvmTranslator6.1 - Attribute List

    RvmTranslator6.1 - Attribute List eryar@163.com 1. Introduction RvmTranslator can translate the RVM ...

  8. javafx KeyCombination

    import javafx.application.Application; import javafx.application.Platform; import javafx.event.Actio ...

  9. janos.io

    http://janos.io/ https://developer.mozilla.org/en-US/Firefox_OS/Developing_Firefox_OS/Porting

  10. windows下go语言环境

    1  liteIDE ,随便装哪儿都行 2  GO语言包 安装  ,我安装到了 c:\go  (顺便给个地址下载地址  https://golang.org/dl/  ) 3  GCC编译器 安装,同 ...