91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

索引優化系列三 聚合因子

發布時間:2020-06-23 20:25:07 來源:網絡 閱讀:325 作者:1415699306 欄目:關系型數據庫

--colocated表根據x列有一定的物理順序

 

drop table colocated purge;

create table colocated ( x int, y varchar2(80) );

begin

    for i in 1 .. 100000

    loop

        insert into colocated(x,y)

        values (i, rpad(dbms_random.random,75,'*') );

    end loop;

end;

/


alter table colocated

add constraint colocated_pk

primary key(x);

begin

dbms_stats.gather_table_stats( user, 'COLOCATED', cascade=>true );

end;

/


--disorganized 表數據根據x列完全無序

drop table disorganized purge;

create table disorganized

as

select x,y

  from colocated

 order by y;

alter table disorganized

add constraint disorganized_pk

primary key (x);

begin

dbms_stats.gather_table_stats( user, 'DISORGANIZED', cascade=>true );

end;

/


set autotrace off

alter session set statistics_level=all;

set linesize 1000



---兩者性能差異顯著

select /*+ index( colocated colocated_pk ) */ * from colocated where x between 20000 and 40000;

SELECT * FROM table(dbms_xplan.display_cursor(NULL,NULL,'runstats_last'));


------------------------------------------------------------------------------------------------------

| Id  | Operation                   | Name         | Starts | E-Rows | A-Rows |   A-Time   | Buffers |

------------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT            |              |      1 |        |  20001 |00:00:00.05 |    2900 |

|   1 |  TABLE ACCESS BY INDEX ROWID| COLOCATED    |      1 |  20002 |  20001 |00:00:00.05 |    2900 |

|*  2 |   INDEX RANGE SCAN          | COLOCATED_PK |      1 |  20002 |  20001 |00:00:00.03 |    1375 |

------------------------------------------------------------------------------------------------------






select /*+ index( disorganized disorganized_pk ) */* from disorganized  where x between 20000 and 40000;

SELECT * FROM table(dbms_xplan.display_cursor(NULL,NULL,'runstats_last'));


---------------------------------------------------------------------------------------------------------

| Id  | Operation                   | Name            | Starts | E-Rows | A-Rows |   A-Time   | Buffers |

---------------------------------------------------------------------------------------------------------

|   0 | SELECT STATEMENT            |                 |      1 |        |  20001 |00:00:00.09 |   21360 |

|   1 |  TABLE ACCESS BY INDEX ROWID| DISORGANIZED    |      1 |  20002 |  20001 |00:00:00.09 |   21360 |

|*  2 |   INDEX RANGE SCAN          | DISORGANIZED_PK |      1 |  20002 |  20001 |00:00:00.03 |    1375 |

---------------------------------------------------------------------------------------------------------



---看聚合因子,就明白真正的原因了。


select a.index_name,

       b.num_rows,

       b.blocks,

       a.clustering_factor

  from user_indexes a, user_tables b

where index_name in ('COLOCATED_PK', 'DISORGANIZED_PK' )

  and a.table_name = b.table_name;


INDEX_NAME                       NUM_ROWS     BLOCKS CLUSTERING_FACTOR

------------------------------ ---------- ---------- -----------------

COLOCATED_PK                       100000       1252              1190

DISORGANIZED_PK                    100000       1219             99899

 


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

常州市| 金溪县| 五峰| 阳泉市| 故城县| 泰兴市| 舒兰市| 宁武县| 卢湾区| 深泽县| 万盛区| 鸡西市| 扶余县| 克拉玛依市| 莱芜市| 东方市| 成安县| 南汇区| 芜湖县| 巴中市| 广东省| 水富县| 元朗区| 宁强县| 腾冲县| 金堂县| 炎陵县| 阳谷县| 辉南县| 房产| 汶川县| 定结县| 宜春市| 上栗县| 抚顺县| 绥德县| 荆门市| 泰宁县| 两当县| 蒙阴县| 甘泉县|