免费注册 查看新帖 |

Chinaunix

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

我这条语句跑了5个半小时啊,高手帮忙优化一下。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-09-10 14:23 |只看该作者 |倒序浏览
需求:
两张表chg(old_acct char[28], new_acct char[28]),org(old_acct char[28], ...);
chg表中两个字段old_acct, new_acct; org表中其中有一个字段old_acct; 现在要将org中的old_acct修改为chg表中相同old_acct对应new_acct.
我写的update语句如下:

  1. update org set org.old_acct = (select chg.new_acct from chg where chg.old_acct = org.old_acct )
  2. where org.old_acct in ( select old_acct  from chg )  
复制代码


现在chg表有20万条记录; org表有2000万条记录。这语句跑了5个小时才跑完啊。。

论坛徽章:
0
2 [报告]
发表于 2007-09-10 14:31 |只看该作者
表的索引信息

论坛徽章:
0
3 [报告]
发表于 2007-09-10 14:35 |只看该作者
chg.old_acct是索引
org.old_acct不是索引

论坛徽章:
0
4 [报告]
发表于 2007-09-10 14:46 |只看该作者
org.old_acct是唯一的?
可以考虑建索引

论坛徽章:
0
5 [报告]
发表于 2007-09-10 14:49 |只看该作者
不是唯一,表的其中一个字段。
条件限制,不能建立索引啊。

论坛徽章:
0
6 [报告]
发表于 2007-09-10 15:09 |只看该作者
chg.old_acct = org.old_acct 根据这个条件 org匹配出的结果集是多少

论坛徽章:
0
7 [报告]
发表于 2007-09-10 15:14 |只看该作者
chg约20万条, 能匹配95%+

论坛徽章:
0
8 [报告]
发表于 2007-09-10 15:15 |只看该作者
原帖由 jack9981 于 2007-9-10 15:14 发表
chg约20万条, 能匹配95%+


对应org 的19w条记录?

在chg表中,old_acct是唯一的?

论坛徽章:
0
9 [报告]
发表于 2007-09-10 15:20 |只看该作者
原帖由 numenhuang 于 2007-9-10 15:15 发表


对应org 的19w条记录?

在chg表中,old_acct是唯一的?

是的。

论坛徽章:
0
10 [报告]
发表于 2007-09-10 15:33 |只看该作者
org表有没有主键,有没有其他选择性比较好的索引
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP