国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

oracle使用索引與不使用索引的性能詳析

2020-07-26 14:00:02
字體:
供稿:網(wǎng)友

前言

Oracle存儲索引的數(shù)據(jù)結(jié)構(gòu)是B*樹。位圖索引也是如此,僅僅只是是葉子節(jié)點不同B*數(shù)索引;

索引由根節(jié)點、分支節(jié)點和葉子節(jié)點組成。上級索引塊包括下級索引塊的索引數(shù)據(jù),葉節(jié)點包括索引數(shù)據(jù)和確定行實際位置的rowid。

使用索引的目的:

  • 加快查詢速度
  • 降低I/O操作
  • 消除磁盤排序

何時使用索引:

  • 查詢返回的記錄數(shù)
  • 排序表<40%
  • 非排序表 <7%
  • 表的碎片較多(頻繁添加、刪除)

索引的種類

  • 非唯一索引(最經(jīng)常使用)
  • 唯一索引
  • 位圖索引
  • 局部有前綴分區(qū)索引
  • 局部無前綴分區(qū)索引
  • 全局有前綴分區(qū)索引
  • 散列分區(qū)索引
  • 基于函數(shù)的索引

oracle使用索引與不使用的性能

首先準備一張百萬條數(shù)據(jù)的表,這樣分析數(shù)據(jù)差距更形象!

下面用分頁表數(shù)據(jù)對表進行分析,根據(jù)EMP_ID 字段排序,使用索引和不使用索引性能差距!

sql查詢語法準備,具體業(yè)務(wù)根據(jù)具體表書寫sql語法:

SELECT *FROM (SELECT ROW_.*, ROWNUM ROWNUM_FROM (SELECT *FROM KQS_SQ_INFO i ORDER BY i.EMP_ID desc ) ROW_WHERE ROWNUM <= 20)WHERE ROWNUM_ >= 10;

使用 explain plan for可以分析sql

如下:

explain plan for SELECT *FROM (SELECT ROW_.*, ROWNUM ROWNUM_FROM (SELECT *FROM KQS_SQ_INFO i ORDER BY i.EMP_ID desc ) ROW_WHERE ROWNUM <= 20)WHERE ROWNUM_ >= 10;

計算出SQL性能,使用

select * from TABLE(dbms_xplan.display);打印出性能分析表

如下圖:

使用索引前:

使用索引后

可以清晰看到使用后cpu使用率很低,并且檢索是從索引開始而不是全文檢索

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對武林網(wǎng)的支持。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 常熟市| 高陵县| 梧州市| 凤城市| 永康市| 日照市| 盐津县| 永泰县| 额敏县| 独山县| 连江县| 乐陵市| 长顺县| 喜德县| 浦城县| 开化县| 河间市| 荣成市| 三都| 清镇市| 甘南县| 阜城县| 沙田区| 唐河县| 嘉义县| 咸宁市| 甘德县| 宜城市| 福贡县| 基隆市| 徐水县| 鄢陵县| 茂名市| 怀化市| 沛县| 应城市| 彭州市| 财经| 聊城市| 栾川县| 遵义县|