如何让oracle的select强制走索引
时间:2022-04-23
本文章向大家介绍如何让oracle的select强制走索引,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
大多数情况下,oracle数据库内置的查询优化策略还是很成功的,但偶尔也有犯2的时候,即使有索引,也会做全表扫描,可以参考以下语句的写法,强制让select语句使用索引
1 CREATE OR REPLACE VIEW V_RES_CBA AS
2 SELECT /*+INDEX(SEG IDX_T_RES_ALLOSEG_ALLOID)*/
3 ALLO.ALLOID AS RESID,
4 NULL AS AWB,
5 ALLO.ALLOTMENT AS ALLO_ID,
6 DAYS.FDATE + NVL(SEG.DAYSDISP, 0) AS FDATE,
7 ALLO.SPECULD AS SPECULD
8 FROM T_RES_ALLO ALLO, T_RES_ALLOSEG SEG, V_FDATE DAYS
9 WHERE ALLO.ALLOID = SEG.ALLOID
10 AND ((ALLO.ALLOIND = 'A' AND ALLO.ALLO_DATE = DAYS.FDATE) OR
11 (ALLO.ALLOIND = 'S' AND
12 NVL(ALLO.SDATE, ALLO.ALLO_DATE) = DAYS.FDATE))
13 UNION
14 SELECT /*+INDEX(SEG IDX_T_RES_ALLOSEG_ALLOID)*/
15 ALLO.ALLOID AS RESID,
16 NULL AS AWB,
17 ALLO.ALLOTMENT AS ALLO_ID,
18 DAYS.FDATE + NVL(SEG.DAYSDISP, 0) AS FDATE,
19 ALLO.SPECULD AS SPECULD
20 FROM T_RES_ALLO ALLO, T_RES_ALLOSEG SEG, V_FDATE DAYS
21 WHERE ALLO.ALLOID = SEG.ALLOID
22 AND ALLO.ALLO_DATE IS NULL
23 AND ALLO.ALLOIND = 'A'
24 AND (DAYS.FDATE >= ALLO.SDATE AND DAYS.FDATE <= ALLO.EDATE AND
25 INSTR(ALLO.WEEKDAY, DAYS.WEEKDAY) > 0)
26 AND NOT EXISTS (SELECT subQuery.ALLOID
27 from T_RES_ALLO subQuery
28 where subQuery.ALLO_DATE = DAYS.FDATE
29 and subQuery.ALLOTMENT = ALLO.ALLOTMENT)
30 ;
要点:
1、/*+INDEX(SEG IDX_T_RES_ALLOSEG_ALLOID)*/ 这里的/*...*/中间不要有空格
2、表名要用别名,即:以上面的sql语句为例,要使用SEG,而不是T_RES_ALLOSEG
- HDUOJ---------Kia's Calculation
- HDUOJ----Good Numbers
- DP较为完整的知识
- HDUOJ----The Number Off of FFF
- HDUOJ-------Naive and Silly Muggles
- HDUOJ----A Computer Graphics Problem
- HDUOJ---(4708)Herding
- HDUOJ---(4708)Rotation Lock Puzzle
- HDUOJ---Hamming Distance(4712)
- HDUOJ-----Difference Between Primes
- HDUOJ----(4706)Children's Day
- poj-------Common Subsequence(poj 1458)
- poj----Maximum sum(poj 2479)
- HDUOJ---hello Kiki
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 微服务[学成在线] day03:CMS页面管理开发
- ggplot2|绘制GO富集柱形图
- 使用Prometheus监控Flink
- 微服务[学成在线] day04:页面静态化
- Spring Boot 整合Mybatis代码生成插件
- Spring Boot 配置文件
- Hello Spring Boot
- Spring Boot 整合Druid
- Spring Boot 整合JDBC
- Spring Boot 整合SpringSecurity
- jacoco-maven-plugin:prepare-agent
- 【LeetCode】两数之和
- 【LeetCode】回文数
- RestTemplate 发送 Https 请求调用
- 【LeetCode】整数反转