首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >数据库(Oracle 11g)连接查询优化

数据库(Oracle 11g)连接查询优化
EN

Stack Overflow用户
提问于 2013-08-28 02:08:48
回答 1查看 653关注 0票数 0

因此,我正在尝试优化一组需要花费大量时间的查询。我想弄清楚的是如何为来自不同表的列创建索引。这里是我的问题的一个简单版本。

我做了什么,

在谷歌搜索之后,我查看了位图索引,但我不确定这是否是解决问题的正确方法。

问题

  1. 有很多到许多关系b/w学生(sid,.)和报告(rid,年份,被删除)
  2. StudentReport(id,sid,rid)是连接表。

查询

代码语言:javascript
复制
Select * 
from Report 
inner join StudentReport on Report.rid = StudentReport.rid
where Report.isdeleted = 0 and StudentReport.sid = x and Report.year = y

创建索引的最佳方法是什么?

EN

回答 1

Stack Overflow用户

发布于 2014-09-29 05:33:11

请试试这个:

代码语言:javascript
复制
with TMP_REP AS (
Select * from Report where Report.isdeleted = 0 AND Report.year = y
)
,TMP_ST_REP AS(
Select * 
from StudentReport where StudentReport.sid = x
)
SELECT * FROM TMP_REP R, TMP_ST_REP S WHERE S.rid = R.rid
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18478317

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档