OPEN SQL中使用 ORACLE HINT

Hint 是Oracle 提供的一种SQL语法,它允许用户在SQL语句中插入相关的语法,从而影响SQL的执行方式。

 

因为Hint的特殊作用,所以对于开发人员不应该在代码中使用它,Hint 更像是Oracle提供给DBA用来分析问题的工具 。在SQL代码中使用Hint,可能导致非常严重的后果,因为数据库的数据是变化的,在某一时刻使用这个执行计划是最优的,在另一个时刻,却可能很差,这也是CBO 取代RBO的原因之一,规则是死的,而数据是时刻变化的,为了获得最正确的执行计划,只有知道表中数据的实际情况,通过计算各种执行计划的成本,则其最优,才是最科学的. 在SQL代码中加入Hint,特别是性能相关的Hint是很危险的做法。

 

ABAP中常见有两种用法:

1.全表扫描:%_HINTS ORACLE 'FULL("table_name")'

2.指定索引:%_HINTS ORACLE 'INDEX("table_name" " index_name")'

 

你可能感兴趣的:(oracle,sql,数据库,table,工具)