如果 WHERE 子句包含未索引的列,是否使用索引
Are indexes used if the WHERE clause contains unindexed columns
我正在使用具有以下索引的 table:
ind1 : column A,B,C,D
ind2 : column G
ind3 : column C
ind4 : column F
ind5 : column D
ind6 : column E
在我的查询中,我使用了以下选择标准:
SELECT * FROM table WHERE
A=a
AND B=b
AND C=c
AND D=d
AND E=e
AND F=f
AND H=h (H does not have an index)
我的问题是是否使用table的索引,如果在这个查询中提高性能,请注意table总共包含12列和32M记录.
是的,查询几乎肯定会使用其中一个索引来预选哪些行可能至少满足某些条件。要检查未索引列(如列 H)的 WHERE 子句是否为真,Oracle 只需检查 table 本身。由于索引指向 table 的正确物理位置,这通常很快。
使用哪个索引,取决于许多因素,例如 table 的大小、索引的大小、table 列的唯一性、索引的唯一性、列值的数据分布等等
要查看您的查询中使用了哪些索引,请查看执行计划,例如您可以在 SQL Developer 中按 F10 查看。
编辑:根据我的经验,Oracle 选择最有前途的索引(这将最大程度地减少行数),然后通过这样的 table 外观检查 WHERE
子句中的所有列向上。
另请确保 table 的统计数据是最新的。如有疑问,请查看
SELECT table_name, last_analyzed FROM USER_TABLES;
如果 last_analyzed 为空或旧日期,请搜索 DBMS_STATS.GATHER_TABLE_STATS 以刷新统计数据。
我正在使用具有以下索引的 table:
ind1 : column A,B,C,D
ind2 : column G
ind3 : column C
ind4 : column F
ind5 : column D
ind6 : column E
在我的查询中,我使用了以下选择标准:
SELECT * FROM table WHERE
A=a
AND B=b
AND C=c
AND D=d
AND E=e
AND F=f
AND H=h (H does not have an index)
我的问题是是否使用table的索引,如果在这个查询中提高性能,请注意table总共包含12列和32M记录.
是的,查询几乎肯定会使用其中一个索引来预选哪些行可能至少满足某些条件。要检查未索引列(如列 H)的 WHERE 子句是否为真,Oracle 只需检查 table 本身。由于索引指向 table 的正确物理位置,这通常很快。
使用哪个索引,取决于许多因素,例如 table 的大小、索引的大小、table 列的唯一性、索引的唯一性、列值的数据分布等等
要查看您的查询中使用了哪些索引,请查看执行计划,例如您可以在 SQL Developer 中按 F10 查看。
编辑:根据我的经验,Oracle 选择最有前途的索引(这将最大程度地减少行数),然后通过这样的 table 外观检查 WHERE
子句中的所有列向上。
另请确保 table 的统计数据是最新的。如有疑问,请查看
SELECT table_name, last_analyzed FROM USER_TABLES;
如果 last_analyzed 为空或旧日期,请搜索 DBMS_STATS.GATHER_TABLE_STATS 以刷新统计数据。