免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2603 | 回复: 2
打印 上一主题 下一主题

语句索引无效? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-09-12 16:18 |只看该作者 |倒序浏览
有两张表 ta_detailbill,tc_mirror数据量分别为119w(ta_detailbill),30w(tc_mirror)  
分别建索引如下:
create index XIE6tc on tc_mirror (
areaid,custid,serviceoldid
)  
create index XIE1ta_detailbill on ta_detailbill(
serviceoldid
)          on seg_ta02
分别对表进行索引的测试(语句where对饮索引字段和顺序),没有问题
然后执行如下语句,1个小时没有出结果
select b.serviceid
from  ta_detailbill a,tc_mirror b
where a.serviceoldid=b.serviceoldid
如果对tc_mirror表的数据量限定,大概需要一分钟出结果
select b.serviceid
from  ta_detailbill a,tc_mirror b
where  b.areaid=1 and b.custid=43843  and a.serviceoldid=b.serviceoldid
如果把tc_mirror表的数据量缩小为112条(把非b.areaid=1 and b.custid=43843数据全部去除),大概需要6秒出结果
select b.serviceid
from  ta_detailbill a,tc_mirror b
where  a.serviceoldid=b.serviceoldid

请问为什么会这么慢?我需要把全表的数据统计到中间表中,如何加快?



----------------
语句有误,原来的tc_servbaseinfo改为tc_mirror;
----------------

[ 本帖最后由 enigmazero 于 2007-9-12 20:37 编辑 ]

论坛徽章:
1
2017金鸡报晓
日期:2017-01-10 15:19:56
2 [报告]
发表于 2007-09-12 20:16 |只看该作者
select b.serviceid from  ta_detailbill a,tc_servbaseinfo b
where a.serviceoldid=b.serviceoldid
没做试验,我猜想查询计划应该是:tc_mirror table_scan ,tc_servbaseinfo index_scan
当然很慢。
select b.serviceid from  ta_detailbill a,tc_servbaseinfo b
where  b.areaid=1 and b.custid=43843  and a.serviceoldid=b.serviceoldid
tc_servbaseinfo 的索引和tc_mirror的索引一致吗?如果一致话,
b.areaid=1 and b.custid=43843  应该可以用的上索引了,但需要看 b.areaid=1 and b.custid=43843 的记录数和ta_detailbill 表的记录数比较确定是谁关联谁?
最后一个例子中数据量小,自然很快了。
使用showplan on可以看到查许计划。

论坛徽章:
0
3 [报告]
发表于 2007-09-12 20:38 |只看该作者
soory,语句有误,原来的tc_servbaseinfo改为tc_mirror;
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP