具有最大长度的mysql聚合

时间:2014-01-20 23:12:03

标签: mysql sql max aggregation

这是我的表

prefix | rate   | provider
------------------------
21366  | 0.1951 | ES
213    | 0.0554 | ES
213    | 0.0567 | 3LV
2136   | 0.189  | 3LV
213    | 0.0481 | vbP
21366  | 0.1894 | vbP
44     | 0.05   | ES
44     | 0.004  | vbP

怎么可能选择前缀X的最低费率,以及所有提供者之间的前缀的最大长度。

例如对于此前缀21366 结果集应该看起来像

2136   | 0.189  | 3LV - The Winner
21366  | 0.1894 | vbP
21366  | 0.1951 | ES

如果提供商具有确切的前缀21366,那么它将是将与其他提供商的费率进行比较的行。如果提供者没有确切的前缀,那么我们会尝试找到所需前缀和提供者前缀之间最长的公共字符串。

我使用此条件匹配前缀WHERE 21366 LIKE CONCAT(前缀, '%' )

首先,找到每个提供商的前缀。然后选择提供商之间的最低费率

1 个答案:

答案 0 :(得分:2)

此查询应返回您需要的行:

SELECT tablename.*
FROM
  tablename INNER JOIN (
    SELECT
      provider, MAX(LENGTH(prefix)) as max_length
    FROM
      tablename
    WHERE
      '21366' LIKE CONCAT(prefix, '%')
    GROUP BY
      provider) m
  ON tablename.provider = m.provider
     AND LENGTH(prefix)=m.max_length

请参阅小提琴here。您可能还想将此添加到您的查询中:

ORDER BY
  rate
LIMIT 1

如果你只需要最低费率。