栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

MYSQL-按限制分组

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MYSQL-按限制分组

我认为MySQL中没有简单的方法。一种方法是通过为按rating_name分组的每一行生成一个行号,然后仅选择row_number为2或更少的行。在大多数数据库中,您可以使用以下方法进行此操作:

SELECt * FROM (    SELECt        rating_name,        etc...,        ROW_NUMBER() OVER (PARTITION BY rating_name ORDER BY good) AS rn    FROM your_table) T1WHERe rn <= 2

不幸的是,MySQL不支持该

ROW_NUMBER
语法。但是,您可以
ROW_NUMBER
使用变量进行模拟:

SELECt    rating_name, id_markets, good, neutral, badFROM (    SELECt        *,        @rn := CASE WHEN @prev_rating_name = rating_name THEN @rn + 1 ELSE 1 END AS rn,        @prev_rating_name := rating_name    FROM (        SELECt rating_name, id_markets, SUM(COALESCE(rating_good, 0)) AS good, SUM(COALESCE(rating_neutral, 0)) AS neutral, SUM(COALESCE(rating_bad, 0)) AS bad        FROM zzratings        WHERe rating_year = YEAR(CURDATE()) AND rating_week = WEEK(CURDATE(), 1)        GROUP BY rating_name, id_markets    ) AS T1, (SELECT @prev_rating_name := '', @rn := 0) AS vars    ORDER BY rating_name, good DESC) AS T2WHERe rn <= 2ORDER BY rating_name, good DESC

对测试数据运行时的结果:

法国1 2 0 0法国2 1 0 0爱尔兰1 4 2 0爱尔兰21 3 1 0波兰1 3 1 0波兰2 1 0 0


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/421310.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号