oracle 如何在一个表中取A列最大的那条记录,如果A列等于最大值同时有多条,取B列最大的那条记录

 我来答
kfounder
2011-11-16 · TA获得超过269个赞
知道小有建树答主
回答量:202
采纳率:0%
帮助的人:155万
展开全部
这个不是一个单纯的SQL就可以完成的,需要使用游标,或者存储过程。
select max(A) from table_name; ----取A列最大的记录,譬如说=100;
select count(A) as countA from table_name where A=100;----取等于最大值的有多少条数据;
然后做判断
if countA =1
------按照你的具体做法实现SQL
else
select max(B) from table_name;
fi
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
flyingFish211
2011-11-16 · TA获得超过2.1万个赞
知道大有可为答主
回答量:1.5万
采纳率:50%
帮助的人:1.1亿
展开全部
select max(A), B
from (select A, B, row_number() over(partition by A order B DESC) rk from tab) t
where rk = 1
group by B
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
micro0369
2017-12-16 · TA获得超过1.2万个赞
知道大有可为答主
回答量:9250
采纳率:85%
帮助的人:4033万
展开全部
select t3.*
from t t3,
(
    select a,max(b) b from t t22,
    ( 
        select max(a) a
        from t t11
    ) t1 where t1.a = t22.a
    group by t22.a
) t2
where t3.a = t2.a and t2.b = t2.b
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式