免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: jack9981
打印 上一主题 下一主题

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

论坛徽章:
0
31 [报告]
发表于 2007-09-11 22:05 |只看该作者
1。统计信息
2。索引
3。执行计划,RBO,CBO
4。改写语句

大致这几个过程,自己惦量

论坛徽章:
0
32 [报告]
发表于 2007-09-12 00:15 |只看该作者
像这种百万以上的数据量,索引是没有用的,有没有索引都是小时的数量级,可以说任何办法都是没有用的,只要你写update
写个存储过程,目标表不要update,而是删了再插入,然后commit,时间以分钟计

论坛徽章:
0
33 [报告]
发表于 2007-09-12 00:20 |只看该作者
原帖由 jack9981 于 2007-9-10 17:06 发表

执行old_acct1, old_acct2转换的时候,就不是主键了啊,我只是说了通用的处理模式。
这个作业只要执行一次就好了。不过总的作业时间不能超过10个小时。现在一张表都是几个字段需要转换,时间不够啊。
而且现 ...


字段转换在临时表里做掉,不要图省事写成cast(a.column)=b.column
否则还是以小时计

论坛徽章:
0
34 [报告]
发表于 2007-09-12 00:25 |只看该作者
还是写程序吧?

论坛徽章:
0
35 [报告]
发表于 2007-09-12 09:19 |只看该作者
原帖由 neoedmund 于 2007-9-12 00:25 发表
还是写程序吧?


正解
跑了5个小时这是由算法决定的,而且在商业数据库不会有更好的算法了
所以多写两行SQL吧。。。

论坛徽章:
0
36 [报告]
发表于 2007-09-12 11:25 |只看该作者
疑问:这样不行吗?
update a set a.colum1=b.colum2 where a.colum1=b.colum1
给a.colum1和b.colum1都建立索引。

为何要写这么复杂呢?

论坛徽章:
0
37 [报告]
发表于 2007-09-12 13:49 |只看该作者
在存储过程中用循环。

论坛徽章:
0
38 [报告]
发表于 2007-09-27 14:57 |只看该作者
感觉写存储过程比较好

论坛徽章:
0
39 [报告]
发表于 2007-10-10 17:46 |只看该作者
用exists替换in

论坛徽章:
0
40 [报告]
发表于 2007-10-10 23:08 |只看该作者
update  (select ta.old_acct old_acct,tb.new_acct new_acct from org ta,t tb
                where ta.old_acct = tb.old_acct)  set old_acct=new_acct;
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP