oracle建立索引

一个表student,系统会经常通过表中三个字段(name,sex,grade)进行搜索,即select*fromstudentwherename='xx'andsex=... 一个表 student ,系统会经常通过 表中三个字段(name,sex,grade)进行搜索,即select * from student where name='xx' and sex='xx' and grade='xx' .
所以要给这三个字段都建立索引,请问怎么建立索引? 有什么要注意的地方么?
展开
 我来答
梦中梦2012
推荐于2018-03-28 · TA获得超过5338个赞
知道小有建树答主
回答量:288
采纳率:75%
帮助的人:347万
展开全部
对三个字段建立索引:
create index Stuname on student(name);
create index Stusex on student(sex);
create index Stugrade on student(grade);
注意的问题,考虑是不是要建立唯一索引(unique),如果有学号的话,可以考虑建立唯一索引引。
再就是对经常查询,但又相对稳定的可以建立聚簇索引,提高查询效率
micro0369
2012-06-04 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:4044万
展开全部
如果查询语法一直是这3列,那么考虑建立3列的联合索引(name,sex,grade) where name='xx' and sex='xx' and grade='xx'

否则,建议在name上建立一个单列索引、在grade上建立单列索引,sex就没有多少必要建单列索引了

如果上述查询经常用到,而按照其他的条件查询的也经常有。

则可以建立上述的3列混合索引,也建立name、grade等的单列索引
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
厍曼冬6o
2012-06-04 · TA获得超过1569个赞
知道小有建树答主
回答量:1336
采纳率:0%
帮助的人:1203万
展开全部
三个字段一起使用,就建立聚合索引,比单独三个索引快
create index idx_Stuname on student(name,sex,grade);
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式