首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > oracle >

group可不可以实现这个种查询,该如何处理

2012-01-16 
group可不可以实现这个种查询selectTableA.goodsid,TableA.price,TableB.timewrittenfromTableB,TableATab

group可不可以实现这个种查询
select       TableA.goodsid,TableA.price,TableB.timewritten   from   TableB,TableA   TableB.seqid=TableA.seqid   group   by   TableA.goodsid,TableA.price,TableB.timewritten  

可不可以在产生的分组中进行排序和只显示每个小组的第一个记录呢,

谢谢,



[解决办法]
如果 GOODSID,PRICE两列一样,楼主想取TIMEWRITTEN 是什么样的,随便一个就可以,还是最大,最小
[解决办法]
select TableA.goodsid,TableA.price,max(TableB.timewritten) from TableB,TableA TableB.seqid=TableA.seqid group by TableA.goodsid,TableA.price

是这样吗?
[解决办法]
select TableA.goodsid,max(TableB.timewritten) from TableB,TableA TableB.seqid=TableA.seqid group by TableA.goodsid
[解决办法]
select TableA.goodsid,max(PRICE),max(TableB.timewritten) from TableB,TableA TableB.seqid=TableA.seqid group by TableA.goodsid

[解决办法]
select *
from
(
select t.*,row_number() over(partition by goodsid order by timewritten desc) rn
from
(
select TableA.goodsid,TableA.price,TableB.timewritten from TableB,TableA
where TableB.seqid=TableA.seqid
)t
)tt
where tt.rn=1

热点排行
Bad Request.