动态取样是为谓词和表/索引统计收集更加精确的信息从而提高服务器性能,信息越精确产生的性能更好。一般发生在生成执行计划阶段。
可以使用动态取样的情况:
1.) 在收集的统计不能使用或会导致严重的估计错误时估计单表的谓词选择性;
2.) 估计没有统计的表/索引的统计;
3.) 估计统计过期的表和索引的统计;
动态取样特征由参数OPTIMIZER_DYNAMIC_SAMPLING控制,默认级别为2。
动态采样是在解析的时候对表进行采样收集统计信息,但不会写入user_tables
动态采样可以通过hint开启无论OPTIMIZER_DYNAMIC_SAMPLING目前的值是多少
取样级别范围从1..10
1级:满足以下条件则采样所有没被分析的表:
(1)查询中至少有一个未分析表;
(2)这个未分析表被关联另外一个表或者出现在子查询或非merge视图中;
(3&#