查询各科成绩前三名的记录:(不考虑成绩并列情况)
sc表,student表,course表
比如某一科的前三名
selcet score ,c_id from sc where c_id=1 order by score limit0,3;
于是
select from sc as s1 where s1.score in (select score from sc where s1.c_id=c_id group by c_id order by score desc limit0,3);
但是这个出了问题,limit 不能有in,看网上说法可以再套一个select,但是有个问题是s1.c_id不认识了
用top 3在mysql又不能用
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步