这是我的桌子

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(前缀, '%' )
所以首先,找到每个提供者的前缀。然后在提供程序之间选择最低速率

最佳答案

此查询应返回所需的行:

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

请参见fiddlehere。您可能还想将此添加到查询中:
ORDER BY
  rate
LIMIT 1

如果你只需要最低的价格。

关于mysql - mysql聚合最大长度,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21246055/

10-11 02:44