首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >最大长度的mysql聚合

最大长度的mysql聚合
EN

Stack Overflow用户
提问于 2014-01-20 23:12:02
回答 1查看 265关注 0票数 1

这是我的桌子

代码语言:javascript
复制
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,结果集应该如下所示

代码语言:javascript
复制
2136   | 0.189  | 3LV - The Winner
21366  | 0.1894 | vbP
21366  | 0.1951 | ES

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

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

因此,首先,查找每个提供者的前缀。然后选择提供者之间的最低速率。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-01-20 23:22:31

此查询应返回所需的行:

代码语言:javascript
复制
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

请看小提琴这里。您还可能希望将此添加到查询中:

代码语言:javascript
复制
ORDER BY
  rate
LIMIT 1

如果你只需要最低的利率。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/21246055

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档