sql server 分组求最大值所在行

有下面的表:作者图书ID图书名称出版日期a1xxxxx2008-1a2xxxxx2009-1b5xxxxx2007-1b8xxxxx2008-2a10xxxxx2009-... 有下面的表:
作者 图书ID 图书名称 出版日期
a 1 xxxxx 2008-1
a 2 xxxxx 2009-1
b 5 xxxxx 2007-1
b 8 xxxxx 2008-2
a 10 xxxxx 2009-5
b 20 xxxxx 2009-8

想得到如下的结果:
作者名称 图书ID 最近出版图书名称 出版日期
a 10 xxxxxx 2009-5
b 20 xxxxxx 2009-8

SQL语句该如何写呢?
这只是截取一些数据,实际上数据很多,作者有许多,不是只有2个,所以top 2 不可行。
展开
 我来答
茅盈智娅玟
2020-04-01 · TA获得超过1187个赞
知道小有建树答主
回答量:1371
采纳率:100%
帮助的人:6.2万
展开全部
最大值:
首先求出所有的非最大值,然后利用集合的差运算即可。
计算所有的非最大值,要利用表自身的笛卡尔积.
列如:
select
scores
from
my_max
where
scores
not
in
(select
a.scores
from
my_max
a,my_max
b
where
a.scores
评论
0
0
加载更多
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式