6

我在 MySQL 中有一个包含列名的表category。我正在尝试编写一个查询,该查询将从每个返回 2 条随机记录category

这是我用来从每个列中获取category最高值的2 条记录的代码rating

SELECT e1.* 
FROM   entries AS e1 
WHERE  (SELECT Count(*) 
        FROM   entries AS e2 
        WHERE  e2.category = e1.category 
               AND e1.rating <= e2.rating) <= 2 
ORDER  BY category, 
          rating DESC 

查看此链接以查看包含一些示例数据和上述查询的表: http ://sqlfiddle.com/#!9/bab8e/1

4

1 回答 1

1

我通过按类别列和随机数对表格进行排序来实现您想要的结果。然后,我为每行分配一个递增的数字,每次类别更改时从 1 开始。然后,我只返回 rowNum 小于或等于 2 的结果。如果您想返回 3 个随机行,只需将其更改为小于或等于 3,依此类推。

SELECT entry_id, 
       category, 
       rating 
FROM   (SELECT @currank := IF(@category = category, @currank + 1, 1) AS rowNum, 
               @category := category                                 AS categoryVar, 
               e1.* 
        FROM   (SELECT *, 
                       (SELECT @currank := 0) r 
                FROM   entries 
                ORDER  BY category, 
                          Rand()) AS e1)AS e2 
WHERE  rownum <= 2 
ORDER  BY category, 
          rating; 

这是一个 sqlfiddle 链接,就像您在问题中发布的那样: http ://sqlfiddle.com/#!9/bab8e/37/0


请注意,同样的查询可以很容易地调整为返回一组非随机的记录。例如,如果您想rating从每个返回前 5 个,category您可以更改

ORDER BY category,rand()

ORDER BY category, rating DESC

和改变

WHERE rownum <= 2

WHERE rownum <= 5

于 2012-12-14T18:35:09.270 回答