免费注册 查看新帖 |

Chinaunix

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

这个SQL竟然跑37S,总感觉逻辑可以优化。但是新手不怎么精通 ,请高手指教。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-06-21 21:26 |只看该作者 |倒序浏览
select count(*) FROM checkout_order_prd prd, delevery_order dlo
   WHERE prd.delevery_order_id = dlo.delevery_order_id
     AND (NOT (    order_status = 9
               AND cancel_type NOT IN (904, 906, 910, 911, 912, 913)
              ) );
checkout_order_prd  799万    delevery_order 759万

输出678万数据,

很高的系统配置
这个SQL竟然跑37S,总感觉逻辑可以优化。但是新手不怎么精通 ,请高手指教。

论坛徽章:
0
2 [报告]
发表于 2012-06-22 00:52 |只看该作者
select count(*) FROM checkout_order_prd,
(
select * from delevery_order where order_status <> 9
               AND cancel_type  IN (904, 906, 910, 911, 912, 913)
) a where prd.delevery_order_id = a.delevery_order_id

论坛徽章:
0
3 [报告]
发表于 2012-06-25 08:21 |只看该作者
回复 2# yangbosos
这样才更慢了,要进行两次全表扫描

   

论坛徽章:
154
2022北京冬奥会纪念版徽章
日期:2015-08-07 17:10:5720周年集字徽章-年
日期:2022-10-26 16:44:2015-16赛季CBA联赛之深圳
日期:2022-11-02 14:02:4515-16赛季CBA联赛之八一
日期:2022-11-28 12:07:4820周年集字徽章-20	
日期:2023-07-19 08:49:4515-16赛季CBA联赛之八一
日期:2023-11-04 19:23:5115-16赛季CBA联赛之广夏
日期:2023-12-13 18:09:34
4 [报告]
发表于 2012-06-25 10:25 |只看该作者
毕竟在两张表上做操作,这很耗资源的

select count(*) FROM checkout_order_prd prd, delevery_order dlo...........

这里
delevery_order dlo

就类似于mysql 里面的表名 as dlo的做法吧
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP