如何让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
- “大数据+定制化服务”或将引领高端旅游市场
- FrameLayout(框架布局)
- WordPress 中变量$allowedposttags 添加自定义HTML属性
- 移动端UC /QQ 浏览器的部分私有Meta 属性
- RelativeLayout(相对布局)
- TableLayout(表格布局)
- 【MindiaX实例】 PHP 在foreach 中获取JSON 单个数据
- 史上十大最严重黑客袭击事件盘点
- LinearLayout(线性布局)
- 服务化了,没想到耦合更加严重?
- 利用好注册的域名
- Android中TextView
- 腾讯 DCI 上线基于集中控制的 SR-TE 方案
- 如何从VS2003升级到VS2008
- 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 数组属性和方法
- AtCoder Beginner Contest 155
- Codeforces Round #620 (Div. 2) A~~D
- DFS+记忆化搜索 -- 简单练习
- AtCoder Beginner Contest 154
- map + pair用法练习
- 蛇形矩阵
- 【SpringBoot WebFlux 系列】 header 参数解析
- URL 去重的 6 种方案!(附详细实现代码)
- 原生JS封装拖动验证滑块你会吗?
- 企业远程视频会议云服务EasyRTC-SFU版本支持 https 功能设计逻辑
- python之编码解码、字符串常用方法
- python之列表
- 一文带你深入理解Mysql索引底层数据结构与算法
- CGI & FastCGI
- 可输出sql的PrepareStatement封装