ORACLE的强制索引
在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。
以EMP表为例:
先在EMP表中建立唯一索引,如图。
普通搜索:
<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; overflow-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">SELECT * FROM EMP T</pre>
查看执行计划:
可以看到,是走的全表扫描。
使用强制索引,在SELECT 后面加上/......./ 中间加上索引的属性,代码如下:
<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; overflow-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">SELECT /+index(t pk_emp)/* FROM EMP T
--强制索引,/...../第一个星星后不能有空格,里边内容结构为:加号index(表名 空格 索引名)。
--如果表用了别名,注释里的表也要使用别名。</pre>
可以看到,这是走的是索引PK_EMP。
merge 过程中走强制索引实例:
因为程序实行时间过长导致程序到回滚段找数据时,发现数据已经被覆盖掉,于是就出现了ORA-01555错误,
修改方案:程序第18段在merge 和 select 都加上强制走索引的语句。
MERGE/*+INDEX(F,IDX_S01_T_EXW_BASIC_DOCUMENTNO)*/
INTO BI_DM.S01_T_EXWAREHOUSE_BASIC_INFOR F
USING (SELECT/*+INDEX(IDX_OMS_WH_OUTB_ORD_REBATE_02)*/ T12.ORDER_NO, T12.IS_REBATE, T12.CREATED, T12.UPDATED
FROM BI_ODS.OW_OMS_WH_OUTBOUND_ORD_REBATE T12
WHERE T12.UPDATED >= DATA_DATE_3D
AND T12.IS_ACTIVE = 'Y'
AND T12.IS_DELETE = 'N') S
ON (F.OVERSEAS_WAREHOUSE_ID = VI_WAREHOUSE_ID AND F.DOCUMENTNO = S.ORDER_NO AND F.DATA_SOURCE = 'OW')
WHEN MATCHED THEN
UPDATE SET F.REBATE_STATUS = S.IS_REBATE;