美文网首页
[SQL]ORACLE的强制索引的方法

[SQL]ORACLE的强制索引的方法

作者: 纵横叹 | 来源:发表于2019-04-30 11:30 被阅读0次

ORACLE的强制索引

在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引,测试查询语句的性能。

以EMP表为例:

先在EMP表中建立唯一索引,如图。

image

普通搜索:

<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>

查看执行计划:

image

可以看到,是走的全表扫描。

使用强制索引,在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>

image

可以看到,这是走的是索引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;

相关文章

  • [SQL]ORACLE的强制索引的方法

    ORACLE的强制索引 在一些场景下,可能ORACLE不会自动走索引,这时候,如果对业务清晰,可以尝试使用强制索引...

  • laravel eloquent 强制mysql使用索引

    为什么需要强制索引? `数据库没有使用我们设想的索引进行sql查询,导致查询特别慢。` mysql强制索引查询语句...

  • sql中强制使用索引

    在工作中遇到sql查询数据较慢时,用explain查看sql索引,发现添加的索引没有生效,那么可以使用强制索引 但...

  • Mysql 索引优化

    联合索引和单个索引选择 对比,值越大越好 强制使用某个索引 使用explain分析索引 1、id:SQL执行的顺序...

  • MySQL实现Oracle中的函数索引

    对于带有列的函数计算的SQL,MySQL 是无法使用索引的,MySQL并没有Oracle中的函数索引,例如: 在O...

  • mysql实现oracle函数索引

    对于带有列的函数计算的SQL,MySQL 是无法使用索引的,MySQL并没有Oracle中的函数索引,例如: 在O...

  • 面试问题记录(二) Day51 2019-01-10

    Oracle 与 MySQL 的区别,分页 数据库最大连接数、存储过程 索引的使用及原理,索引未命中,各种SQL的...

  • 索引

    索引的概念及创建 学习一下索引。索引应该是Oracle的初级内容中比较重要的一部分。因为是否创建索引,对SQL的查...

  • SQL语句优化

    MySQL和Oracle 阿里开发强制要求的11条SQL编写规范 MySQL大表优化 应尽量避免在 where 子...

  • Oracle提高SQL执行效率的三种方法

    Oracle提高SQL执行效率的三种方法 (修改了一下) 要提高SQL在Oracle里的执行效率,优化应用的业务逻...

网友评论

      本文标题:[SQL]ORACLE的强制索引的方法

      本文链接:https://www.haomeiwen.com/subject/ghvmnqtx.html