【问题标题】:Select MAX() of Multiple Columns in MySQL在 MySQL 中选择多列的 MAX()
【发布时间】:2015-07-26 04:50:03
【问题描述】:

我目前有一个大型查询(使用 PHP 和 MySQL),我不确定如何优化它以减少其 18-25 秒的大量负载。我查看了以前的答案,发现他们都编写了类似的大量代码,导致类似的脚本执行时间,所以我想看看是否有人会有任何替代想法而不是已经存在的想法提出:

TLDR;我需要为每个分析 ID 选择最大列,这会带来巨大的负载,因此我需要以某种方式减少它

$qry = "SELECT DISTINCT ip,country_code,country,
(SELECT MAX(region)  FROM analytics RegOne WHERE bid='$id' AND RegOne.ip= IPOne.ip) AS region,
(SELECT MAX(city)    FROM analytics CitOne WHERE bid='$id' AND CitOne.ip= IPOne.ip) AS city,
(SELECT MAX(os)      FROM analytics OSOne  WHERE bid='$id' AND OSOne.ip= IPOne.ip) AS os,
(SELECT MIN(browser) FROM analytics BroOne WHERE bid='$id' AND BroOne.ip= IPOne.ip) AS browser,
(SELECT MIN(resolution) FROM analytics ResOne  WHERE bid='$id' AND ResOne.ip= IPOne.ip) AS resolution,
(SELECT MAX(timestamp)  FROM analytics DateOne WHERE bid='$id' AND DateOne.ip= IPOne.ip) AS LatestDate
FROM analytics AS IPOne
WHERE bid='$id'
ORDER BY LatestDate DESC
LIMIT 15 OFFSET $offset";

这是从一个大表中获取数据,所以我不希望它花费 0 秒,但是任何时间减少都可以,而不是 ~21 秒。

【问题讨论】:

    标签: php mysql mariadb


    【解决方案1】:

    为什么不

    SELECT ip, country_code, country,
         MAX(region) as region,
         MAX...
         MAX(timestamp) as LatestDate
    FROM analytics
    WHERE bid = '$id'
    GROUP BY ip, country_code, country
    ORDER BY LatestDate DESC
    LIMIT 15 OFFSET $offset";
    

    您应该有一些以bid 开头的索引。这可能会更好:

    INDEX(bid, ip, country_code, country)
    

    【讨论】:

    • 我会这样做。避免 SELECT 列表中的相关子查询通常会提供更好的性能。
    【解决方案2】:

    (bid, ip) 上应该有一个复合 KEY。 如果您在(bid) 上有 KEY,则添加(或替换为)(bid, ip)

    【讨论】:

    • 我只是将它们编入索引;由于某种原因,它没有让我将它们都设为主键/复合键,但是谢谢!索引似乎很有魅力
    • @Josh "key" 和 "index" 在 MySQL 中的含义相同。您只能拥有一个主键,您可以拥有任意数量的其他键。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-11-24
    • 2022-10-06
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多