MySQL 为其中的每个 id 获取最新的 3 行

标签 mysql sql select sql-order-by greatest-n-per-group

我有以下查询,据说它会为每个 update_id 获取最新的 3 条评论。它似乎有效,直到我发现一个逻辑问题,无论更新如何,它都会获得最新的 3 条评论;它应该为每个 update_id 获取最新的 3 条评论。我怎样才能做到这一点?显然 limit(3) 是错误的。

SELECT  `comms` . * ,  `usr`.`name` 
FROM (
`comms`
)
JOIN  `users` AS usr ON  `usr`.`id` =  `comms`.`user_id` 
WHERE  `update_id` 
IN (
'1451',  '1416',  '1186',  '1157',  '1150',  '1122',  '1057',  '914',  '850',  '816',  '794',  '790',  '749',  '746',  '745',  '744',  '740'
)
ORDER BY  `id` DESC 
LIMIT 3

最佳答案

试试这个:

SELECT A.*, u.name 
FROM (SELECT c.*, IF(@updateId = @updateId:=update_id, @idx:=@idx+1, @idx:=0) idx 
      FROM comms c, (SELECT @updateId:=0, @idx:=0) A
      WHERE update_id IN ('1451', '1416', '1186', '1157', '1150', '1122', '1057', '914', '850', '816', '794', '790', '749', '746', '745', '744', '740')
      ORDER BY update_id, id DESC   
    ) AS A 
INNER JOIN users AS u ON u.id = A.user_id
WHERE A.idx < 3

关于MySQL 为其中的每个 id 获取最新的 3 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21086593/

相关文章:

MySQL 复制 Tungsten 与 Galera

mysql - MYSQL中获取距离10km的记录

php - LIMIT 和 OFFSET - 如果偏移量大于行数或查询返回的记录少于 5,则从头开始

mysql - 尝试操作存储过程中的数据时显示空值

php - HTML 选择中的 MySQL 列

python - 在数据库中实现匹配

c# - LINQ 连接多对多关系

php - UPDATE 中的 CASE 用于选择列

mysql - PHP MYSQL 比较日期时间

angularjs - ng-options 禁用选项但仍将其显示为选中