zoukankan      html  css  js  c++  java
  • 如何优化因将Btree索引转换成位图索引(BITMAP CONVERSION )而导致SQL执行很慢

        

        在Oracle 9i以上,Oracle有时候会选择将B-Tree索引进行BITMAP转换来进行SQL执行,从而导致极其恶劣的执行计划。

    该转换由隐藏参数_b_tree_bitmap_plans决定。如果该参数为true,则进行转换,否则不进行转换。而8i里,该参数缺省为false

    所以只有存在bitmap索引时才会考虑将B树索引转换为bitmap; 而到了9i里,该参数缺省为true了,则对任何索引都有可能进行

    bitmap转换。

     

    解决办法有两个:

    1.通过过对_b_tree_bitmap_plans参数调整,禁用将B-tree索引转换成位图索引

     

           alter system set "_b_tree_bitmap_plans"=false;

           Select Name ,Value From v$parameter Where Name ='_b_tree_bitmap_plans' 

    在下图中BITMAP CONVERSION FROM / TO ROWIDS 就是进行了位图转换后的执行计划:

    BitmapConvert.png

    在客户的数据库系统中,一旦这个SQL执行了位图转换,其执行时间就会拉长到50秒左右,而且单进程会占用100%的CPU资源,而禁用转换,则CPU资源使用正常,40几个毫秒就可以执行完成。

    SQL> alter session set "_b_tree_bitmap_plans"=false;
    Session altered.
    Elapsed: 00:00:00.01
    SQL> @sql
    COUNT(DISTINCTTAB2.WFID)
    ------------------------
                         708
    Elapsed: 00:00:00.41
    SQL> alter session set "_b_tree_bitmap_plans"=true;
    Session altered.
    Elapsed: 00:00:00.00
    SQL> @sql
    COUNT(DISTINCTTAB2.WFID)
    ------------------------
                         708

    Elapsed: 00:00:52.80

    最后选择在全局设置隐含参数 _b_tree_bitmap_plans ,禁用了位图转换。

    2.通过执行包begin dbms_stats.gather_table_stats('用户','表名');END; 重新统计表的信息 
     
  • 相关阅读:
    3.19 DAY2
    3.18 DAY1
    MySql Scaffolding an Existing Database in EF Core
    asp.net core 2.0 后台定时自动执行任务
    c#中枚举类型 显示中文
    fullCalendar使用经验总结
    Web APP 日期选择控件
    【转】剖析异步编程语法糖: async和await
    【转】Entity Framework 复杂类型
    【转】EF Code First 学习笔记:约定配置
  • 原文地址:https://www.cnblogs.com/HondaHsu/p/2624735.html
Copyright © 2011-2022 走看看