Mysql多选哪里快速高效?

时间:2014-06-23 13:00:53

标签: mysql select where

我有以下mysql查询正常工作,只有问题是:它真的很慢。有没有人建议我,如果有更好的方法来执行这样的查询?

SELECT 
(select sum(tot) FROM NOI_per_order_perf_global WHERE DATE(datte) = DATE(NOW()) AND origin_country = 'fr') as yoofr,
(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY AND  contry = 'fr') as yooyestfr, 
(select sum(tot) FROM table1 WHERE yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014 AND contry = 'fr') as yooyesttfr,
(select sum(tot) FROM table1 WHERE MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014 AND contry = 'fr') as yooyestttfr,
(select MAX(datte) FROM table1 WHERE contry = 'fr') as timingfr,

(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) AND contry = 'de') as yoode,
(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY AND  contry = 'de') as yooyestde, 
(select sum(tot) FROM table1 WHERE yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014 AND contry = 'de') as yooyesttde,
(select sum(tot) FROM table1 WHERE MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014 AND contry = 'de') as yooyestttde,
(select MAX(datte) FROM table1 WHERE contry = 'de') as timingde,

(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) AND contry = 'it') as yooit,
(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY AND  contry = 'it') as yooyestit, 
(select sum(tot) FROM table1 WHERE yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014 AND contry = 'it') as yooyesttit,
(select sum(tot) FROM table1 WHERE MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014 AND contry = 'it') as yooyestttit,
(select MAX(datte) FROM table1 WHERE contry = 'it') as timingit,

(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) AND contry = 'es') as yooes,
(select sum(tot) FROM table1 WHERE DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY AND  contry = 'es') as yooyestes, 
(select sum(tot) FROM table1 WHERE yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014 AND contry = 'es') as yooyesttes,
(select sum(tot) FROM table1 WHERE MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014 AND contry = 'es') as yooyestttes,
(select MAX(datte) FROM table1 WHERE contry = 'es') as timinges,
谢谢,马克。

1 个答案:

答案 0 :(得分:1)

每个县带回一行可能会更有效率: -

SELECT origin_country, 
        SUM(IF(DATE(datte) = DATE(NOW()), tot, 0)) AS yoofr,
        SUM(IF(DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY, tot, 0)) AS yooyestfr, 
        SUM(IF(yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014, 0)) AS yooyesttfr,
        SUM(IF(MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014, 0)) AS yooyestttfr,
        MAX(datte) AS timingfr
FROM table1
WHERE origin_country IN ('fr', 'de', 'it', 'es')
GROUP BY origin_country

但这仍然不会很好(索引在和字段中的用处不会太多)

这可能会允许使用索引(如果有用的话): -

SELECT sub1.origin_country, yoofr, yooyestfr, yooyesttfr, yooyestttfr, timingfr
FROM
(
    SELECT origin_country, sum(tot) as yoofr,
    FROM table1
    WHERE origin_country IN ('fr', 'de', 'it', 'es')
    AND DATE(datte) = DATE(NOW())
    GROUP BY origin_country
) sub1
INNER JOIN
(
    SELECT origin_country, sum(tot) as yooyestfr 
    FROM table1
    WHERE origin_country IN ('fr', 'de', 'it', 'es')
    AND DATE(datte) = DATE(NOW()) - INTERVAL 1 DAY
    GROUP BY origin_country
) sub2 ON sub1.origin_country = sub2.origin_country
INNER JOIN
(
    SELECT origin_country, sum(tot) as yooyesttfr 
    FROM table1
    WHERE origin_country IN ('fr', 'de', 'it', 'es')
    AND yearweek(`datte`, 1) = yearweek(curdate(), 1) AND YEAR(datte)=2014
    GROUP BY origin_country
) sub3 ON sub1.origin_country = sub3.origin_country
INNER JOIN
(
    SELECT origin_country, sum(tot) as yooyestttfr 
    FROM table1
    WHERE origin_country IN ('fr', 'de', 'it', 'es')
    AND MONTH(datte) = MONTH(CURDATE()) AND YEAR(datte)=2014
    GROUP BY origin_country
) sub4 ON sub1.origin_country = sub4.origin_country
INNER JOIN
(
    SELECT origin_country, MAX(datte) as timingfr 
    FROM table1
    WHERE origin_country IN ('fr', 'de', 'it', 'es')
    GROUP BY origin_country
) sub5 ON sub1.origin_country = sub5.origin_country

然而,其中很多将取决于实际表格上的索引