lnkToKing 2016-09-12 02:24 采纳率: 0%
浏览 1505

mysql 分组合计sql求优化

有两表T1,T2。

T1约9000条数据,有以下列:

id,eid,name

T2约50000条数据,有以下列:

id,eid,num



现要查出T1表中eid在T2表中同一个eid的num合计,其中求合计后的数据总数sql如下,耗时5秒,求优化:

SELECT COUNT(*) FROM(
SELECT T1.id,T1.eid,T1.name, t.num FROM T1
LEFT JOIN (SELECT eid, COUNT(*) AS num FROM T2 GROUP BY eid) t ON t.eid = T1.eid
WHERE t.num > 0
) t
  • 写回答

5条回答

  • lpsky0865 2016-09-12 03:11
    关注

    必须这样写啊,弟弟

    SELECT count(*) FROM T1
     INNER JOIN (SELECT eid, COUNT(*) AS num FROM T2 GROUP BY eid HAVING COUNT(*)>0) t ON t.eid = T1.eid 
    
    评论

报告相同问题?

悬赏问题

  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?
  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发