伙计们,我想从特定年份的下表中获得前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)
答案 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
答案 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,您也不应该根据您尝试执行的操作来关注该值。