oracle查询表中某一列所有不同分组的某个一列的最大值,并且返回这一行所有列的值。

查询auctionid为85、79的auctionprice为最大值的那两行,并且返回这一行所有列的值。或者返回ID列。我做出来了,这个为查询方法SELECTid,use... 查询auctionid为85、79的auctionprice为最大值的那两行,并且返回这一行所有列的值。或者返回ID列。
我做出来了,这个为查询方法
SELECT id,userid,auctionid,auctiontime,auctionprice
FROM (SELECT ROW_NUMBER() OVER(PARTITION BY auctionid ORDER BY auctionid DESC) rn,
auctionrecord.*
FROM auctionrecord)
WHERE rn = 1 ;
展开
 我来答
alex_jiarui
2015-06-29 · 超过65用户采纳过TA的回答
知道小有建树答主
回答量:101
采纳率:0%
帮助的人:110万
展开全部
可以考虑使用row_number() over(partition by auctionid)来获得纪录排序,然后获得排序中的第一条记录就可以了。
但是效率不会太高。
追问
谢谢。我刚好也做出来。分给你了,你的方法是对的。。顺便请求科普一下,怎么看执行效率,以及提高执行效率的方法。
追答
你用的应该是 plsqldev吧,直接快捷键F5就可以了。
至于提高效率的方法,一般我考虑的是通过表设计来达到效果。
还有就是用索引。
如果这个查询要经常用,而且效率要求高,那么估计我会用一个表存放每个aucionid的最大值所在的ID,写入前判断是否更新这个ID。
如果要对程序端透明,那就用trigger了,但是这个写入性能下降了。这个还是要看你的使用场景。
appsna
2015-06-29 · TA获得超过801个赞
知道小有建树答主
回答量:392
采纳率:60%
帮助的人:148万
展开全部
(select * from table_name where auctionid='79' and rownum=1 order by auctionprice desc )

union
(select * from table_name where auctionid='85' and rownum=1 order by auctionprice desc );
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式