SQL两个表的联合查询语句

 我来答
辉绪量5
2019-05-17 · TA获得超过3万个赞
知道大有可为答主
回答量:1.1万
采纳率:32%
帮助的人:704万
展开全部
select
*
from
(select
a.姓名编号,a.姓名,b.考试科目
as
科目,b.成绩,row_number()over(partition
by
a.姓名
order
by
b.成绩
desc)
as
id
from
表一
a,表二
b
where
a.姓名=b.姓名)
where
id
=
1;
说明:
1、上面的sql是按照成绩降序排列后取出每个姓名的第一条记录,如果想换成升序把【order
by
b.成绩
desc】改成【order
by
b.成绩】即可。
2、如果想取第二条记录把【where
id
=
1;】改成【where
id
=
2;】即可。
3、如果想去前n条把【where
id
=
1;】改成【where
id
<=n;】即可。
---
以上,希望对你有所帮助。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式