在mysql中从数据库中获取max(顶部的一些数据)

时间:2012-07-23 18:39:32

标签: mysql max

伙计们,我想从特定年份的下表中获得前3名疾病以及他们的数量......我应该运行什么样的查询?

mysql> select id,dname,d_id,entrydate from patient_master;    
+----+------------------+------+------------+    
| id | dname            | d_id | entrydate  |     
+----+------------------+------+------------+          
|  1 | Root Canal       |    1 | 2012-08-02 |         
|  2 | Cosmetic Filling |    3 | 2012-05-10 |   
|  3 | Root Canal       |    1 | 2012-05-25 |   
|  4 | High BP          |    6 | 2012-07-09 |    
|  5 | Root Canal       |    1 | 2012-07-10 |      
|  6 | Normal Filling   |    2 | 2012-05-10 |     
|  7 | Maleria          |    4 | 2012-07-10 |    
|  8 | Maleria          |    4 | 2012-07-12 |    
|  9 | Typhoid          |    5 | 2012-07-12 |    
+----+------------------+------+------------+    
9 rows in set (0.00 sec)

2 个答案:

答案 0 :(得分:2)

使用group by子句按疾病组合结果,并使用count(*)计算每种疾病的记录数。然后,您可以从最大到最少订购,并使用limit 3仅获得前3名。我还添加了where子句,仅过滤2012中的记录。

  select count(*), dname
    from patient_master
   where entrydate between '2012-01-01' and '2013-01-01'
group by dname
order by count(*) desc
   limit 3

演示:http://www.sqlfiddle.com/#!2/89c06/6

答案 1 :(得分:0)

SELECT d_id, dname, count(d_id) as `count`, year(entrydate) as `year`
FROM patient_master
GROUP by `year`, d_id
ORDER BY `year` DESC, `count` DESC

注意我没有在这里设置限制,就好像你想要获得同一个查询中的年份和计数一样,你需要编写一个非常复杂的查询来获得每年前三名。

这将按年份递减,然后根据每年的疾病计数下降。您将注意到能够在此查询中获取行ID,您也不应该根据您尝试执行的操作来关注该值。