=========================================
========ZMOS_02===========================
=========================================
[SQL]
SELECT COUNT(*)
FROM FDC_DATA
WHERE EQPID = :B4
AND UNIT = :B3
AND PPID=:B2
AND SENSOR=:B1
AND EVENTTIME>SYSDATE-1/24
-----------------------------------------------------------------------------------
| Id | Operation | Name | Starts | A-Rows | A-Time | Buffers |
-----------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 1 |00:00:00.25 | 18125 |
| 1 | SORT AGGREGATE | | 1 | 1 |00:00:00.25 | 18125 |
|* 2 | INDEX FULL SCAN| FDC_DATA_IDX1 | 1 | 1 |00:00:00.25 | 18124 |
-----------------------------------------------------------------------------------
OLD INDEX:
FDC_DATA_IDX1 : SYSID, EQPID, UNIT, PPID, SENSOR, PRODUCT, EVENTTIME, SPEC
---------------------------------------------------------------------------------------------
SELECT COUNT(*),COUNT(DISTINCT(SYSID) SYSID_NDV,.................... FROM TABLE;
NDV(Number Of Distinct Value)
COUNT(*) SYSID_NDV EQPID_NDV UNIT_NDV PPID_NDV SENSOR_NDV GLASSID_NDV
--------- --------- --------- --------- --------- ---------- -----------
650430 100675 115 656 1515 2233 30139
NEW INDEX:
FDC_DATA_IDX1 : SYSID
FDC_DATA_IDX2 : EQPID, UNIT, PPID, EVENTTIME, SENSOR, GLASSID
------------------------------------------------------------------------------------
| Id | Operation | Name | Starts | A-Rows | A-Time | Buffers |
------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 1 |00:00:00.001 | 3 |
| 1 | SORT AGGREGATE | | 1 | 1 |00:00:00.001 | 3 |
|* 2 | INDEX RANGE SCAN| FDC_DATA_IDX2 | 1 | 1 |00:00:00.001 | 3 |
------------------------------------------------------------------------------------
理解:创建index时
1. 分析应用SQL条件中使用到的字段和后续各字段数据量的增长情况;
2. 要检查table各字段的distinct数量值;
3. 理论上建立复合索引时,distinct数量值高的字段应该放在复合索引首位,因为分布度高;
4. 如果某字段distinct数量值非常高,不建议使用太多字段的复合索引,建议单独建立或者少字段的复合索引;
index range scan(索引范围扫描):
1.对于unique index来说,如果where 条件后面出现了<,> ,between ...and...的时候,那么就可能执行index range scan,如果where条件后面是=,那么就会执行index unique scan。
2.对于none unique index来说 如果where 条件后面出现了=,>,<,betweed...and...的时候,就有可能执行index range scan。
3.对于组合索引来说,如果where条件后面出现了组合索引的引导列,那么可能执行index range scan。
index fast full scan(索引快速全扫描):
如果select 语句后面中的列都被包含在组合索引中,而且where后面没有出现组合索引的引导列,并且需要检索出大部分数据,那么这个时候可能执行index fast full scan。index fast full scan 发生的条件:
1.必须是组合索引。2.引导列不在where条件中
index skip scan(索引跳跃式扫描)
当查询可以通过组合索引得到结果,而且返回结果很少,并且where条件中没有包含索引引导列的时候,可能执行index skip scan
索引跳跃式扫描发生的条件:
1.必须是组合索引。
2.引导列没有出现在where条件中
有待测试。
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31401608/viewspace-2148689/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/31401608/viewspace-2148689/