通过以下示例来详细演示如何分析执行计划:例如,假设存在一个名为LARGE_TABLE的大表,且其username列上没有索引。执行以下SQL语句: SQL> SELECT * FROM LARGE_TABLE WHERE USERNAME = 'TEST'; 查询计划 ----- SELECT STATEMENT Optimizer=CHOOSE (Cost=1234 Card=1 Bytes=14) TABLE ACCESS FULL LARGE_TABLE [:Q65001] [ANALYZED] 在这个例子中,第一个操作是TABLE ACCESS FULL LARGE_TABLE,表示在LARGE_TABLE表上进行全表扫描。操作完成后,生成的数据行源被传递到下一步骤处理。在这个例子中,SELECT STATEMENT是查询语句的最后一步。 Optimizer=CHOOSE指明了查询的优化器模式,即optimizer_mode初始化参数的值,而不是查询执行时实际使用的优化器。实际使用的优化器由后面的cost部分决定。如果cost的形式如下所示,则表明使用的是CBO优化器。此处的cost表示优化器估计的执行计划成本。